Тёмный

JVM Architecture 

BigDataElearning
Подписаться 7 тыс.
Просмотров 72 тыс.
50% 1

ATTENTION DATA SCIENCE ASPIRANTS:
Click Below Link to Download Proven 90-Day Roadmap to become a Data Scientist in 90 days
www.bigdataele...
Java Course for Data Science Beginners : www.bigdataele...
Official Website : bigdataelearni...
This video explains about the internals of the JVM architecture. In this video, I am going to explain about the 3 major components of JVM architecture,
Class Loader, runtime data area, and execution engine.
class loader is the first main component in JVM architecture, which has 3 phases loading, linking, and initialization. First let’s look at the loading phase of class loader component. In the loading phase, we have 3 types of class loaders.
The class loaders are of 3 types. bootstrap class loader, extension class loader, and application class loader. Bootstrap class loader is the one that is responsible for loading the class files from Rt dot jar(rt.jar) also called as runtime jar. Extension class loader is the one that is responsible for loading the additional class files from jre lib ext (jre/lib/ext) folder. For example, if we are working on programs that interact with queues like IBM mq, we may need mq specific jars to be able to connect to the queue. Or if we are working on connecting to oracle databases, we need ojdbc dot jar. in these scenario, we add these third-party jar files to the extension folder. Application class loader is the one that loads the class files from the application specific jar. This is nothing but the application that you created. Once your java program is compiled, the JVM creates class files. The Application class loader loads these class files to the memory area.
Second main component in JVM architecture is the run time data area. Just like how a car needs a road, or how a train needs a railway track to run, similarly JVM needs memory area to store the class files and execute them.
There are 5 types of memory data area. They are method area, Heap memory, Stack memory, PC Registers, and Native method stacks
Method area- all the class level data are stored in this memory area. For example, class level static variables are stored in this memory area.
Heap memory - all the objects and instance variables are stored in this memory area.
Stack memory - this contains three sections of memory areas.
Local variable - memory area that stores all the local variables that is used within a method
Operand stack - contains all the operands that are used within a method.
Frame data - this contains any catch block information, in case any exception occurs within method.
PC registers - this memory area holds the current executing instructions
Native method stacks - memory area which holds the native method information
The 3rd main component in JVM architecture is the execution engine. This is the actual engine that converts the bytecode to machine code and executes the instructions. This contains Interpreter, JIT compiler, Garbage collector, and Java Native method interface.
Interpreter - Interpreter is the one that reads the class files or bytecode and executes it one by one. The problem with the interpreter is that, when a method is called multiple times, it interprets those lines of bytecode again and again.
JIT compiler - JIT compiler helps in overcoming the problem of the interpreter. When repeated method calls occur, JIT compiler compiles the bytecode to native code. This native code will be used directly for repeated method calls. JIT compiler contains few components to achieve this feature
Intermediate code generator - generates intermediate code
Code optimizer - optimizes the intermediate code for better performance
Target code generator - converts intermediate code to native machine code
Profiler - it is responsible for finding the hotspots, methods which are called repeatedly.
Garbage collector - Garbage collector is responsible for destroying the objects that are no longer used.
Java native method interface - It is responsible for interacting with native libraries and makes it available for the JVM execution engine.
In this video, we saw that the JVM architecture has 3 main components namely class loader, run time data area, and execution engine.
Class loader in turn has 3 subsystems, which are loading phase, linking phase, and initialization phase.
Second main component is the Runtime data area, which has 5 memory areas namely method area, heap memory, stack memory, PC registers and JNI.
The 3rd main component is the execution engine. This contains some components like interpreter, JIT compiler, JNI, and Garbage collector.
In the next video, we will look at the “Class structure and components”

Опубликовано:

 

14 окт 2024

Поделиться:

Ссылка:

Скачать:

Готовим ссылку...

Добавить в:

Мой плейлист
Посмотреть позже
Комментарии : 40   
Далее
Class Structure and components - Part I
3:11
Просмотров 3,6 тыс.
JVM ( java virtual machine) architecture - tutorial
29:16
The Java Memory Model - The Basics
23:41
Просмотров 129 тыс.
Multithreading in Java Explained in 10 Minutes
10:01
Просмотров 935 тыс.
Android - Погружение в JVM
1:48:48
Просмотров 8 тыс.
Just In Time (JIT) Compilers - Computerphile
10:41
Просмотров 274 тыс.
#26 Stack And Heap in Java
12:37
Просмотров 261 тыс.
Learn Java in 15 Minutes (seriously)
19:50
Просмотров 81 тыс.
JVM Anatomy 101
55:48
Просмотров 21 тыс.
Memory Fundamentals - part 1 of Java Memory Management
18:31