HotSpot (HotSpot)
HotSpot | |
---|---|
Тип | Java Virtual Machine |
Разработчики | Oracle (ранее Sun Microsystems) |
Написана на | C++ |
Операционная система | Кроссплатформенное ПО |
Первый выпуск | 1999[1] |
Последняя версия | 25.77-b03 |
Лицензия | GNU General Public License |
Сайт | openjdk.java.net/groups/… |
«HotSpot» — основная виртуальная машина Java (JVM) как для клиентских, так и для серверных компьютеров, выпускаемая корпорацией «Oracle». Для повышения производительности обладает технологиями динамической компиляции JIT и адаптивной оптимизации.
История
[править | править код]«HotSpot», впервые выпущенная 27 апреля 1999 года, изначально разрабатывалась «Longview Technologies» — небольшой компанией, основанной в 1994 году. В 1997 году компанию купила Sun Microsystems[2]. Сначала «HotSpot» использовали как дополнение к «Java 1.2», однако, эта виртуальная машина стала основной с выходом «Java 1.3»[3].
Этимология
[править | править код]Эта JVM называется «HotSpot» потому что, выполняя байт-кода «Java», она ищет его «горячие» места (англ. «hot spots») — многократно выполняющиеся. Поиск направлен на оптимизацию их выполнения: выделение им больших ресурсов вместе с уменьшением непроизводительных затрат для выполнения менее ресурсоёмкого кода.
Перспективы
[править | править код]«HotSpot» часто называют самой производительной виртуальной машиной Java в своём классе. В теории, — с помощью адаптивной оптимизации, — программа, которая выполняется в этой JVM, может быть более производительной, чем эквивалентная ей программа в машинных кодах[4].
Особенности
[править | править код]Виртуальная машина «HotSpot» написана на «C++». Как указано на домашней странице «HotSpot», размер её исходного кода составляет 250 000 строк[5]. «Hotspot» предоставляет следующую функциональность:
- Загрузчик Java-классов;
- Интерпретатор байткода;
- Две версии виртуальной машины — Client и Server;
- Несколько сборщиков мусора;
- Набор вспомогательных библиотек времени выполнения.
Client-версия виртуальной машины характеризуется меньшим временем запуска приложений и меньшим потреблением памяти по сравнению с Server-версией, уступая при этом последней в производительности.
JVM-флаги
[править | править код]«HotSpot» поддерживает большое количество аргументов командной строки[англ.] для настройки виртуальной машины при запуске. Некоторые из них — стандартные и поддерживаются другими реализациями JVM, другие же — нет, так как специфичны (опции, которые начинаются с -X
или -XX
)[6][7][8][9].
Лицензия
[править | править код]13 ноября 2006 года виртуальная машина и JDK от Sun Microsystems были открыты[10] под лицензией GPL v2 (см. Sun’s OpenJDK Hotspot page). Этот код стал частью Java 7.
Поддерживаемые платформы
[править | править код]Поддерживаемые Sun Microsystems
[править | править код]Что касается JDK, HotSpot на данный момент поддерживается Oracle в операционных системах Microsoft Windows, Linux и Solaris. Поддержка ISAs представлена платформами IA-32, x86-64 и SPARC (только в Solaris).[11]
Порты от сторонних разработчиков
[править | править код]Доступны также порты сторонних разработчиков для Mac OS X и других операционных систем Unix. Поддерживается несколько различных аппаратных архитектур, включая x86, PowerPC и SPARC (только в Solaris).
Портирование HotSpot усложнено тем, что данная виртуальная машина написана в основном на C++ с использованием вставок на ассемблере[12]. Чтобы избежать этого, проект IcedTea разработал общий порт интерпретатора HotSpot под названием zero-assembler Hotspot (или просто zero) который практически не содержит ассемблерного кода. Данный порт разрабатывается с целью достижения портируемости HotSpot на различные процессорные архитектуры Linux, что сделает его практически неограниченно портируемым. Код zero-assembler Hotspot используется для всех архитектур, отличных от x86 (PPC, IA64, S390 и ARM), начиная с версии 1.6[13][14][15].
Гари Бенсон (англ. Gary Benson), разработчик IcedTea, в данный момент разрабатывает платформонезависимую реализацию динамической компиляции JIT под названием Shark для HotSpot, с использованием LLVM, в дополнение к zero-assembler Hotspot[16][17].
См. также
[править | править код]Примечания
[править | править код]- ↑ https://web.archive.org/web/thefreelibrary.com/Sun+Announces+Availability+of+the+Java+HotSpot+Performance+Engine%3b...-a054477747 — 1999.
- ↑ Sun's Gosling Previews Hotspot Java Virtual Machine . ComputerGram (13 февраля 1998). Дата обращения: 25 июля 2010.
- ↑ Sun Microsystems releases fastest client-side Java platform to date . Sun Microsystems (8 мая 2000). Дата обращения: 25 июля 2010. Архивировано из оригинала 3 мая 2012 года.
- ↑ Lewis, J.P. Performance of Java versus C++ (2004). Дата обращения: 25 июля 2010. Архивировано из оригинала 3 мая 2012 года.
- ↑ The HotSpot Group . Sun Microsystems (2007). — «There are nearly 1500 C/C++ header and source files, comprising almost 250,000 lines of code». Дата обращения: 21 июля 2010. Архивировано из оригинала 3 мая 2012 года.
- ↑ Java HotSpot VM Options . Sun Microsystems. Дата обращения: 8 февраля 2009. Архивировано из оригинала 3 мая 2012 года.
- ↑ Mocker, Joseph D. A Collection of JVM Options (28 августа 2007). Дата обращения: 20 июля 2010. Архивировано из оригинала 13 октября 2012 года.
- ↑ Maximovich, Dmitri The most complete list of -XX options for Java 6 JVM . Дата обращения: 20 июля 2010. Архивировано из оригинала 30 января 2010 года.
- ↑ Nutter, Charles My Favorite Hotspot JVM Flags (29 января 2009). Дата обращения: 20 июля 2010. Архивировано из оригинала 3 мая 2012 года.
- ↑ Sun Opens Java . Sun Microsystems (13 ноября 2006). Дата обращения: 20 июля 2010. Архивировано из оригинала 3 мая 2012 года.
- ↑ Supported System Configurations . Oracle. Дата обращения: 1 января 2011. Архивировано из оригинала 3 мая 2012 года.
- ↑ Gary, Benson Gary's guide to porting IcedTea (6 ноября 2007). Дата обращения: 21 июля 2010. Архивировано из оригинала 3 мая 2012 года.
- ↑ Gary, Benson 1st February 2008 (1 февраля 2008). Дата обращения: 21 июля 2010. Архивировано из оригинала 3 мая 2012 года.
- ↑ Andrew, Haley Making zero-assembler the default on ppc (31 января 2008). Дата обращения: 21 июля 2010. Архивировано из оригинала 3 мая 2012 года.
- ↑ Lilian, Angel IcedTea 1.6 Released with Zero-assembler and JNLP support! Red hat (13 февраля 2008). Дата обращения: 21 июля 2010. Архивировано из оригинала 3 мая 2012 года.
- ↑ Gary, Benson 31 March 2008 . Red hat (21 июля 2010). Дата обращения: 30 мая 2008. Архивировано из оригинала 3 мая 2012 года.
- ↑ Gary, Benson 28 May 2008 . Red hat (28 мая 2008). — «Shark is a platform-independent JIT for HotSpot, to complement the zero-assembler interpreter we’ve been using». Дата обращения: 21 июля 2010. Архивировано из оригинала 3 мая 2012 года.