Java virtuaalmasin
Java virtuaalmasin (inglise keeles Java Virtual Machine) on abstraktne masin, mis interpreteerib kompileeritud Java baitkoodi arvuti protsessorile arusaadavateks instruktsioonideks. Java virtuaalmasina puhul on tegemist abstraktsioonikihiga, mis võimaldab jooksutada Java baitkoodiks kompileeritud rakendusi riistvaraplatvormist sõltumata. Masin tagab, et baitkood valideeritakse ning täidetakse korrektselt.
Levinuim Java virtuaalmasina implementatsioon on Oracle poolt hallatav HotSpot.[1]
Spetsifikatsioon
muudaIga Java virtuaalmasina implementatsioon peab järgima Java virtuaalmasina spetsifikatsioone. Java virtuaalmasina spetsifikatsioon määratleb üldised nõuded virtuaalmasina implementatsioonidele, et tagada kõikide Java virtuaalmasinate toimimine standardiseeritud moel. Iga Java baitkoodiks kompileeritud rakendus peab olema võimeline jooksma sellises masinas, mis Java virtuaalmasina spetsifikatsioone implementeerib.[2]
Arhitektuur
muudaTüübid
muudaJava virtuaalmasinas on kaks erinevat tüüpi: primitiivsed tüübid ning viitetüübid (reference types). Spetsifikatsioon defineerib 9 primitiivset tüüpi:
- Numbrilised tüübid
- Täisarvulised tüübid:
byte
,short
,int
,long
,char
- Ujuvkomaarv tüübid:
float
,double
- Täisarvulised tüübid:
- Tõeväärtustüüp
boolean
returnAddresss
– tüüp, mis hoiab viiteid Java virtuaalmasina instruktsioonide operatsioonikoodidele (opcodes) ja on ainuke primitiivne tüüp, millel pole Java programmeerimiskeeles ühest vastet.
Viitetüübid jagunevad kolmeks: klassitüübid, massiivitüübid ja liidesetüübid (interface types). Nende tüüpide väärtused vastavad dünaamiliselt loodud klassi, massiivi või liidese tüübi instantsidele.[2]
Mälukasutus
muudaJava virtuaalmasin defineerib mitmeid mälustruktuure, mis on tarvilikud masina tööks. Mõningad struktuurid on globaalsed virtuaalmasina kontekstis ning mõned struktuurid on eraldi iga lõime jaoks. Java virtuaalmasin kasutab enda töös nii registreid kui ka pinusid.[2]
pc
register- Igal lõimel on oma
pc
(program counter) register, mis viitab lõime poolt hetkel jooksutatavale instruktsioonile.
- Igal lõimel on oma
- Virtuaalmasina pinud
- Igal lõimel on oma privaatne pinu, mis initsialiseeritakse lõime loomisel.
- Pinus hoitakse kohalikke muutujaid ning hallatakse meetodite väljakutsete ahelat.
- Kuhi (heap)
- Kuhi on kõikide lõimede jaoks ühine ning selles alas hoitakse klasside instantse ning massiive. Kuhi luuakse Java virtuaalmasina loomise hetkel.
- Kuhja mälukasutust haldab automaatne prügikoristuse (garbage collection) süsteem.
- Meetodite tsoon (Method area)
- Ala on kõikidel lõimedel ühine ning luuakse Java virtuaalmasina loomise hetkel.
- Siin hoitakse kompileeritud programmikoodi ning klassidega seonduvat infot nende meetodite ning väljade kohta.
- Omameetodite pinu (Native method stack)
- Java virtuaalmasin võimaldab välja kutsuda meetodeid, mis ei ole Java programmeerimiskeeles kirjutatud. Selliste meetodite väljakutsed hoitakse lõime privaatsest pinust eraldi.
- Pinu luuakse lõime loomise hetkel.
Klasside laadimine
muudaJava virtuaalmasina spetsifikatsioon kirjeldab detailselt Java klassifailide formaadi ning nende laadimise funktsionaalsust. Klassilaadija (class loader) peab olema suuteline tuvastama ja laadima korrektseid Java klassifaile.[2] Klassilaadija toimib klassi laadimisel järgmisi samme jälgides:
- Laadimine: klassilaadija leiab ja laeb vastava klassi tüübi baidid
- Linkimine: toimub verifitseerimine, ettevalmistamine ning viidete lahendamine
- Verifitseerimine: klassi tüübi korrektsuse tagamine
- Ettevalmistamine: klassi muutujate jaoks mälu reserveerimine
- Viidete lahendamine: teatud virtuaalmasina instruktsioonid võivad kasutada sümboolseid viiteid (symbolic reference) klassi tüübi viidete tabelis (constant pool) esinevatele väärtusele. Selle sammu käigus lahendatakse need viited, et kätte saada viidetele vastavad objektid.
- Initsialiseerimine: Java koodi väljakutsumine, mis omistab klassi muutujatele vastavad algväärtused
JIT kompilaator
muudaTavaline virtuaalmasina töökäik näeb ette, et masin interpreteerib sisendiks antud Java baitkoodi instruktsioone, mis on aeglasem, kui platvormispetsiifilise masinkoodi jooksutamine. Selle probleemi lahendamiseks rakendab Java virtuaalmasin JIT (just in time) kompileerimismeetodit. JIT kompilaator võimaldab programmi käitamisajal teatud programmilõike teisendada masinkoodiks, et seeläbi tagada nende osade kiirem täitmine. Sellist kompleerimise meetodit rakendatakse programmi osade peal, mida kõige tihedamini jooksutatakse. JIT kompilaatori olemasolu parandab oluliselt Java virtuaalmasinas jooksvate rakenduste jõudlust.[2]