HotSpot

Эта статья находится на начальном уровне проработки, в одной из её версий выборочно используется текст из источника, распространяемого под свободной лицензией
Материал из энциклопедии Руниверсалис
HotSpot
Тип Java Virtual Machine
Разработчик Oracle (ранее Sun Microsystems)
Написана на C++
Операционная система Кроссплатформенное ПО
Последняя версия 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[1]. Сначала «HotSpot» использовали как дополнение к «Java 1.2», однако, эта виртуальная машина стала основной с выходом «Java 1.3»[2].

Этимология

Эта JVM называется «HotSpot» потому что, выполняя байт-кода «Java», она ищет его «горячие» места (англ. «hot spots») — многократно выполняющиеся. Поиск направлен на оптимизацию их выполнения: выделение им больших ресурсов вместе с уменьшением непроизводительных затрат для выполнения менее ресурсоёмкого кода.

Перспективы

«HotSpot» часто называют самой производительной виртуальной машиной Java в своём классе. В теории, — с помощью адаптивной оптимизации, — программа, которая выполняется в этой JVM, может быть более производительной, чем эквивалентная ей программа в машинных кодах[3].

Особенности

Виртуальная машина «HotSpot» написана на «C++». Как указано на домашней странице «HotSpot», размер её исходного кода составляет 250 000 строк[4]. «Hotspot» предоставляет следующую функциональность:

Client-версия виртуальной машины характеризуется меньшим временем запуска приложений и меньшим потреблением памяти по сравнению с Server-версией, уступая при этом последней в производительности.

JVM-флаги

«HotSpot» поддерживает большое количество аргументов командной строки[en] для настройки виртуальной машины при запуске. Некоторые из них — стандартные и поддерживаются другими реализациями JVM, другие же — нет, так как специфичны (опции, которые начинаются с -X или -XX)[5][6][7][8].

Лицензия

13 ноября 2006 года виртуальная машина и JDK от Sun Microsystems были открыты[9] под лицензией 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).[10]

Порты от сторонних разработчиков

Доступны также порты сторонних разработчиков для Mac OS X и других операционных систем Unix. Поддерживается несколько различных аппаратных архитектур, включая x86, PowerPC и SPARC (только в Solaris).

Портирование HotSpot усложнено тем, что данная виртуальная машина написана в основном на C++ с использованием вставок на ассемблере[11]. Чтобы избежать этого, проект IcedTea разработал общий порт интерпретатора HotSpot под названием zero-assembler Hotspot (или просто zero) который практически не содержит ассемблерного кода. Данный порт разрабатывается с целью достижения портируемости HotSpot на различные процессорные архитектуры Linux, что сделает его практически неограниченно портируемым. Код zero-assembler Hotspot используется для всех архитектур, отличных от x86 (PPC, IA64, S390 и ARM), начиная с версии 1.6[12][13][14].

Гари Бенсон (англ. Gary Benson), разработчик IcedTea, в данный момент разрабатывает платформонезависимую реализацию динамической компиляции JIT под названием Shark для HotSpot, с использованием LLVM, в дополнение к zero-assembler Hotspot[15][16].

См. также

Примечания

  1. Sun's Gosling Previews Hotspot Java Virtual Machine. ComputerGram (13 февраля 1998). Дата обращения: 25 июля 2010.
  2. Sun Microsystems releases fastest client-side Java platform to date (недоступная ссылка). Sun Microsystems (8 мая 2000). Дата обращения: 25 июля 2010. Архивировано 3 мая 2012 года.
  3. Lewis, J.P. Performance of Java versus C++ (недоступная ссылка) (2004). Дата обращения: 25 июля 2010. Архивировано 3 мая 2012 года.
  4. 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 года.
  5. Java HotSpot VM Options (недоступная ссылка). Sun Microsystems. Дата обращения: 8 февраля 2009. Архивировано 3 мая 2012 года.
  6. Mocker, Joseph D. A Collection of JVM Options (недоступная ссылка) (28 августа 2007). Дата обращения: 20 июля 2010. Архивировано 13 октября 2012 года.
  7. Maximovich, Dmitri The most complete list of -XX options for Java 6 JVM (недоступная ссылка). Дата обращения: 20 июля 2010. Архивировано 30 января 2010 года.
  8. Nutter, Charles My Favorite Hotspot JVM Flags (недоступная ссылка) (29 января 2009). Дата обращения: 20 июля 2010. Архивировано 3 мая 2012 года.
  9. Sun Opens Java (недоступная ссылка). Sun Microsystems (13 ноября 2006). Дата обращения: 20 июля 2010. Архивировано 3 мая 2012 года.
  10. Supported System Configurations (недоступная ссылка). Oracle. Дата обращения: 1 января 2011. Архивировано 3 мая 2012 года.
  11. Gary, Benson Gary's guide to porting IcedTea (недоступная ссылка) (6 ноября 2007). Дата обращения: 21 июля 2010. Архивировано 3 мая 2012 года.
  12. Gary, Benson 1st February 2008 (недоступная ссылка) (1 февраля 2008). Дата обращения: 21 июля 2010. Архивировано 3 мая 2012 года.
  13. Andrew, Haley Making zero-assembler the default on ppc (недоступная ссылка) (31 января 2008). Дата обращения: 21 июля 2010. Архивировано 3 мая 2012 года.
  14. Lilian, Angel IcedTea 1.6 Released with Zero-assembler and JNLP support! (недоступная ссылка). Red hat (13 февраля 2008). Дата обращения: 21 июля 2010. Архивировано 3 мая 2012 года.
  15. Gary, Benson 31 March 2008 (недоступная ссылка). Red hat (21 июля 2010). Дата обращения: 30 мая 2008. Архивировано 3 мая 2012 года.
  16. 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 года.

Ссылки