Macchina virtuale Java: differenze tra le versioni
Contenuto cancellato Contenuto aggiunto
Nessun oggetto della modifica |
m gcj - problemi di framework |
||
Riga 3:
La '''macchina virtuale Java''', detta anche '''Java Virtual Machine''' o '''JVM''', è la [[macchina virtuale]] che esegue i programmi in linguaggio [[bytecode]], ovvero i prodotti della [[compilatore|compilazione]] dei [[codice sorgente|sorgenti]] Java. La JVM è formalmente una [[specifica]], mantenuta da [[Sun Microsystems]]. Qualsiasi sistema che si comporti in modo coerente con tale specifica sarà quindi da considerarsi una particolare [[implementazione]] della JVM. Esistono implementazioni [[software]] per praticamente tutti i [[sistema operativo|sistemi operativi]] moderni, sia gratuite che commerciali. Inoltre, esistono implementazioni che operano in contesti [[hardware]]/[[software]] particolari, per esempio [[telefono cellulare|telefoni cellulari]], e persino implementazioni hardware.
Le specifiche della JVM vengono dettate e aggiornate dalla [[Sun Microsystems]] in quanto iniziatore del progetto, di cui è ancora il mantenitore, ma vengono spesso disattese dalla maggioranza delle implementazioni non-sun di JVM che sono in circolazione, soprattutto per quanto riguarda il framework che ogni jvm include . Di conseguenza, le diverse JVM non sono totalmente compatibili tra loro ed occorre fare attenzione nello scrivere i programmi, se si vuole che essi funzionino su ogni JVM . La cosa migliore da fare a tale scopo sarebbe non usare le ultime caratteristiche del linguaggio introdotte dalla SUN nelle JVM piu' recenti e usare delle API 'stabili' , che cioe' siano presenti nella JVM SUN da varie versioni .
Le ultime JVM Sun, e alcune altre implementazioni che sono reperibili, hanno metodi efficaci per ridurre il consumo di [[CPU]], tra i quali l'HotSpot <sup>(tm)</sup>, un metodo di precompilazione del [[bytecode]] in maniera tale da avere alcune parti già tradotte in linguaggio macchina, pronte per essere eseguite quando necessario.
Riga 10:
Di conseguenza la Server HotSpot avrà risposta minore all'avvio, in confronto alla Client HotSpot che inizia subito con l'esecuzione, ma sarà tendenzialmente più efficiente durante tutta l'esecuzione. Per questi motivi si usa la Server HotSpot per programmi [[server]] appunto, o in generale per programmi che resteranno in esecuzione a lungo e per i quali il tempo di avvio non è importante.
Un altro approccio possibile (anche se piu' problematico ,per i motivi visti sopra) potrebbe essere compilare il programma java in un codice nativo anziche' in bytecode , usando ad esempio il compilatore gcj della FSF (anche se ne esistono molti altri. )
[[Categoria:Sun]]
|