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» предоставляет следующую функциональность:

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].

См. также

Примечания

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

Ссылки