Jupiter JVM - Jupiter JVM

Jupiter JVM
Konečné vydání
1.0.0 beta / 15. července 2002 (2002-07-15)
TypVirtuální stroj Java
LicenceGPL
webová stránkawww.eecg.toronto.edu/Jupiter

Jupiter JVM je open-source Virtuální stroj Java, která byla vyvinuta jako diplomová práce s ohledem na modularitu a rozšiřitelnost. Využívá to Sběratel odpadků Boehm a GNU Classpath. Hlavní aspekty jeho návrhu virtuálního stroje Jupiter lze zjednodušit jako:

  • Lokalita paměti - Objekty jsou na haldě přidělovány s malým nebo žádným ohledem na lokalitu. I když tento přístup může být vhodný pro uniprocesory nebo malé SMP, je nepravděpodobné, že bude dobře fungovat na klastru pracovních stanic, kde je vzdálený přístup k paměti o jeden nebo dva řády pomalejší než přístup k místní paměti.
  • Paralelní sběr odpadu - Sběr odpadu může zabrat značné množství času aplikace. Typicky JVM zaměstnávají „stop-the-world“ sběrače odpadků, kde jsou podprocesy programu zastaveny během sběru odpadků. Tento přístup nebude fungovat u velkého počtu procesorů, a to ze dvou důvodů. Zaprvé, náklady na „zastavení světa“ jsou podstatně vyšší, když je počet procesorů velký. Za druhé, použití jediného vlákna ke sběru odpadků vede k nepřijatelně velké sekvenční frakci pro jakoukoli aplikaci.
  • Model konzistence paměti - K dosažení škálovacího výkonu u mnoha procesorů je důležité využít „uvolněného“ Model paměti Java. V současné době žádný JVM neimplementuje JMM věrně a mnozí jej implementují nesprávně, což vede k nedostatečné koherenci a ztrátě optimalizačních příležitostí. Specifikace JMM byla rovněž revidována v roce 2007.
  • Účinný vlákna a synchronizace - U mnoha procesorů je zásadní zajistit efektivní podporu podprocesů a synchronizační mechanismy, které se dobře rozšiřují.

Viz také

externí odkazy