Java Virtual Machine
1. Class Loader
2. Run - Time Data Area
3. Execution Engine
1. Class Loader ----------> a. Loading
b. Linking
c. Initialisation Loading ------------------> Bootstrap Loader
--------> Application Loader
--------> Extension Loader
Bootstrap Loader loads the system class from RT.Jar to the Run Time Memory. The system class is written inside the RT.Jar and this RT.Jar will load this system class into the memory. So it is done by the Bootstrap Loader.
Source file ----compiled----> .class file
This .class file is loaded in the run time memory with the help of Application Loader.
Extension Class Loader is responsible for loading additional class files from .jre or .ext folder.
If you have a source code if you need to connect this source code with some data base then you need ojdbc.jar class file in this scenario we add this 3rd party jar file into the extension class loader and extension class loader makes the pre compiled class file available to the JVM by loading files into the memory area.
Linking ---------------> it is required to verify the generated .class file verification is what, once the class file is loaded to the memory then there is a verification phase
and this verification is done by the linking phase.
Linking-------verifies-------->class files
Where the byte code class file is verified if it's confirmed to the standards or not.
2. Run-Time Data Area is the 2nd main component of JVM. JVM needs a memory area to store the class files. This run-time memory area is comprised of many types of memories like method area, heap memory area, stack memory area etc.
Stack Memory Application :-
Stack is a data structure
Stack is a abstract sata type
Stack can be performed by two main operations PUSH and POP
PUSH -> Inserting item one by one when pushing is done stack is known as full.
POP -> Deleting item one by one starting from the top of the stack. Now when the stack is empty the pop operation is done.
Think JVM contains stack
Visualize JVM divided into 3 part. And this stack is part of 2nd component Run-Time Data Area Component.
The purpose of this stack whenever we write javap-c<class_name> in command
prompt then we we'll able to see a byte code this byte code is comprised of two operations PUSH and POP or LOAD and STORE.
3. Execution Engine is the actual JVM execution engine that converts byte code in to the Machine Code and executes the instructions.
Interpreter -> Interpreter reads the class file or the byte code and executes it one by one.
Here is a problem, whenever interpreter reads a particular file if there exists any repeated calling procedure i.e when a method is called multiple times, it interprets those lines again and again. This is the main problem with the interpreter and this problem is solved by JIT Compiler. JIT Compiler solves this problem by using a special component which is known as profiler.
Profiler will find the hotspot where the repeated function or method calling appears and then repeatedly executed codes are converted to native code by profiler so, that it can avoid repeated method calls. So, it is very important that the interpreter is responsible for execution the specific part of byte code and interpreter suffers from a problem of looping again and again where repeated method calling exists.
Garbage Collector is a member of the 3rd component of the JVM. This garbage collector has the responsibility of collecting or destroying the object which is no longer used.
0 Comments