Juice (JVM)
From Wikipedia, the free encyclopedia
JUICE is a J2ME experimental Java Virtual Machine written in C language according to the Sun Microsystem specifications. The Juice JVM, designed for real-time Java, was specifically developed to run on the NUXI operating system. The most relevant features of Juice are related to the structure for the heap memory, to the object allocation policy and to the garbage collector used.
Contents |
[edit] The Heap Memory in Juice
In Juice, all the available heap memory is shared in "chunks" of pre-fixed size. The memory unit used is the "d-word" (that stands for "double-word"). The actual default size of the chunks is fixed to 64 d-words. The free memory chunks are organized in a linked list, while the chunks occupied by Java Objects are connected to each other through a hierarchical structure in a way that remembers the representation of the UNIX file system.
[edit] The real-time object allocation policy
The object allocation policy in Juice is strictly connected to the structure used to represent the Heap memory. Because of this structure, it becomes possible to allocate (and deallocate) Java Objects in a time that is dependent only on the size of the Object itself (predictability).
[edit] The Pay-per-Use garbage collector
The proposed garbage collector is based on a non-copying tracing collector that performs memory reclamation only when a new object has to be allocated. The name of the garbage collector is due to the fact that the cost payed by the mutator, in terms of wasted time for collector execution, is proportional to the size of the object to allocate.
[edit] Authors
Garbage Collector, Heap Memory Management: Corrado Santoro, Roberto Aloi
All the rest: Corrado Santoro
[edit] References
A. Corsaro, C. Santoro. Optimizing JVM Object Operations to Improve WCET Predictability, article presented to the 4th International Workshop on Worst-Case Execution Time, 2004.
A. Corsaro, C. Santoro. A C++ Native Interface for Interpreted JVMs. In 1st Intl. JTRES Workshop (JTRES’03). LNCS 2889, Springer, 2003.
R. Aloi. Memory Management and Garbage Collection in Real-time Java(Italian), thesis in Computer Engineering (University of Catania, Italy), 2005.