29 August 2013
Array initialization
Java class file stores array initializers as a sequence of explicit array-element initializers, equivalent to data[0]=1, data[1]=2; data[2]=3; instead of comcact block of packed bytes.
19 August 2013
JVM internals: Runtime data areas
When a Java virtual machine runs a program, it needs memory to store many things, including bytecodes and other information it extracts from loaded class files, objects the program instantiates, parameters to methods, return values, local variables, and intermediate results of computations. The Java virtual machine organizes the memory it needs to execute a program into several runtime data areas.
Overview of all data areas:
Overview of all data areas:
Let's talk about each one in detail.
Data areas individual for each thread:
- The pc Register - program counter register. Each JVM thread has its own pc register. At any time JVM thread executing method and if that method is not native, the pc register contains the address (in Method Area) of next instruction to execute, but is method is native then pc register's value is undefined.
- Stack. JVM stack stores the state of each Java (not native) method invocations for the thread. State of method invocation placed in stack frame (or simply frame), so then thread invokes method, new frame created and pushed to stack, and then method completes frame poped and discarded from virtual machine. State of frame contains local variables, parameters of method, return result, intermediate calculations also know as operand stack (as JVM is stack-based VM, it has no registers to store intermediate calculations) and reference to current class constant pool. The sizes of local variable array and the operand stack are determined at compile-time. Only one frame is active at any point of thread execution and this frame is called current frame and it's method known as current method. It should be mention, the memory for JVM stack doesn't have to be contiguous.
- Native Method Stack. Native method stack also called as "C stack". Native method stack is used for native method invocation and also may be used by the implementation of a JVM bytecode interpreter.
Interaction between Java stack and Native Method Stack:
Data areas shared by all threads:
- Heap.
- Method Area. Method area is used to store per-class structures such as
runtime constant pool, field and method data, code for methods and constructors
(including special methods used in class or object initialization). Method area
is created on virtual machine start up and it is logical part of heap. JVM
provide control over minimum and maximum size of method area or just initial
size.
- Runtime Constant Pool. Runtime constant pool is per-class or per-interface runtime
representation of the constant_pool table in a class file. It contains several
kinds of constants ranging from literal constants known at compile time to method
and field references resolved at runtime. Runtime constant pool is constructed
when class or interface created in virtual machine.In class file constant pool is represented as array of structures like:
constant_info {
u1 tag;u1 info[];}
Tag is 1 byte value which is vary from 1 to 18 and represents one of constant type.
· CONSTANT_Utf8 (1)
u1 tag – constant type (1)u2 length – number of bytes in byte arrayu1 bytes[length] – contains bytes of string (byte value > 0 i. e. in range (0; 0x0F)) (strings is encode in modified UTF-8)
· CONSTANT_Class (7)
tag - constant type (7)name_index - index of CONSTANT_Utf8 entry in constant_pool
· CONSTANT_FieldRef (9)
· CONSTANT_MethodRef (10)
· CONSTANT_InterfaceMethodRef (11)
u1 tag – constant typeu2 class _index – index of CONSTANT_Class entry in constant poolu2 name_index – index of CONSTANT_NameAndType entry in constant pool
· CONSTANT_String (8)
u1 tag – constant type (8)u2 string_index – index of CONSTANT_Utf8 entry in constant pool to which the String object is to be initialized
· CONSTANT_Integer (3)
· CONSTANT_Float (4)
u1 tag – constant typeu4 bytes – value of constant in bytes in big-endian order (high order first)
· CONSTANT_Long (5)
· CONSTANT_Double (6)
u1 – constant typeu4 hight_bytesu4 low_bytesVALUE = ((long) high_bytes << 32) + low_bytes
· CONSTANT_NameAndType (12)
u1 tag – constant typeu2 name_index – method or field nameu2 descriptor_index – method or field descriptorField descriptor –§ B – byte§ C – char§ D – double§ F – float§ I – integer§ J – long§ L ClassName ; - reference§ S – short§ Z – Boolean§ [ - array dimension (one bracket per dimension)Method descriptor – (FieldDescriptor*)ReturnDecriptor (return descriptor may be V – void or FieldDescriptor)
· CONSTANT_MethodHandle (15)
u1 tag – constant typeu1 reference_kind – value denotes the kind of method handle, which characterizes its bytecode behavior and lies in range 1 to 91. REF_getField + CONSTANT_Field2. REF_getStatic + CONSTANT_Field3. REF_putField + CONSTANT_Field4. REF_putStatic + CONSTANT_Field5. REF_invokeVirtual + CONSTANT_MethodRef (all methods excludingand ) 6. REF_invokeStatic + CONSTANT_MethodRef (all methods excludingand ) 7. REF_invokeSpecial + CONSTANT_MethodRef (all methods excludingand ) 8. REF_newInvokeSpecial + CONSTANT_MethodRef (only) 9. REF_invokeInterface + CONSTANT_InterfaceMethodRef (all methods excludingand ) u2 reference_index – value of CONSTANT_Field, _MethodRef, _InterfaceMethodRef
· CONSTANT_MethodType (16)
u1 tag – constant typeu2 descriptor_index – valid index of CONSTANT_Utf8 entry in constant_pool which representing a method descriptor
· CONSTANT_InvokeDynamic (18)
u1 tag – constant typeu2 bootstrap_method_attr_index – valid index of bootstrap_methods array of the bootstrap method table of current class fileu2 name_and_type_index – valid index of CONSTANT_NameAndType entry in constant_pool representing method name and method descriptor
JVM internals: VM types
Like the Java programming language JVM operated two kinds of types: primitive and reference types.
All type checking performed by compiler, and does not have to be done by JVM.
VM primitive data types:
All type checking performed by compiler, and does not have to be done by JVM.
VM primitive data types:
- numeric
- byte - 8-bit signed / [-128;127];
- short - 16-bit signed [-32768; 32767];
- char - 16-bit unsigned [0; 65535];
- int - 32-bit signed [-2147483648; 2147483647];
- float - 32-bit precision (IEEE 754 standard);
- long - 64-bit signed [-;];
- double - 64-bit precision (IEEE 754 standard).
- boolean - JVM provides limited support to boolean data type. There are no VM instructions solely dedicated to operation on boolean type. Expressions to operate boolean type are compiled to use int data type (int value 1 - true, int value 0 - false). JVM directly supports boolean arrays as byte arrays (so it using 8 bytes per boolean value and bytecode instructions that are also suitable for byte arrays):
- newarray - creates boolean array;
- baload - access to boolean array;
- bastore - modify boolean array.
- returnAddress - returns pointer to the opcodes of JVM instructions. The data type used by JVM instructions: jsr, jsr_w, ret. Anlilke other JVM datatypes, returnAddress doesn't correspond to any Java programming language type and cannot be modified by running program.
VM reference types:
- class types;
- interface types;
- array types.
A VM reference may be null reference - reference to no object and default value of any reference. Null reference initialy in runtime has no type, but may be cast to any reference type.
Subscribe to:
Posts (Atom)