java基石-JVM

我对java这门语言的理解:

  主要从以下几个方面阐述:1、java平台无关性(跨平台,一次编译,到处运行);2、GC;3、语言特性(反射,泛型,lamda表达式);4、面向对象(封装,继承,多态);5、类库(java本身自带的集合,并发库,网络库,IO,NIO等;6、异常处理)

如何实现平台无关的:

  编译期javac命令可以把java源文件编译成.class的字节码文件,运行时:不同平台的JVM解析,而不需要重新编译,JVM执行字节码的时候把字节码转换成具体平台的机器指令。

JVM的构成:1、Class Loader,依据指定格式加载class文件到内存。2、Execution Engine 命令解释器 3、Runtime Data Area(Heap,Stack,Method Area,Native Method Stack)内存结构模型 4、Native Interface 融合不同开发语言原生库为java所用。

谈谈ClassLoader:

  JVM的核心组件,主要工作在class的装载阶段,所有的class都是由classLoader加载的,负责将class的二进制数据流装载进系统,交给虚拟机进行连接,初始化等操作。主要由以下4类:

  1、BootStrapClassLoader:C++编写,加载核心库java。

  2、ExtClassLoader:java编写,加载扩展库javax.*。

  3、AppClassLoader:java编写,加载程序所在目录。

  4、自定义的ClassLoader :java编写,定制化(实现findClass来获得Class的字节数据,然后defineClass方法生成类的字节码返回)。

  为什么类加载器为什么要使用双亲委派机制:避免多份同样字节码的加载。

classLoader和ForName的区别

  类的加载方式:1、隐式加载 new  2、显式加载 classLoader、ForName。

  类的装在过程:1、加载,通过classLoader加载class文件字节码,生成Class对象; 2、链接 (校验,准备,解析)3、初始化 执行类变量赋值和静态代码块。

  Class.forName得到的class是已经初始化的。

  ClassLoader.loaderClass得到的class还没有经过链接(ioc中使用这种方式延时加载,从而提升加载性能)。

Java内存模型 jdk8

局部变量表和操作数栈的区别与联系:

局部变量表:包含方法执行时所包含的所有局部变量。bool byte char long short int float,double.

操作数栈:入栈,出栈,复制,交换,产生消费变量。

线程私有:

  1、程序计数器,

  2、本地方法栈,

  3、虚拟机栈(方法执行的内存模型,每个方法执行时都会创建一个栈帧即方法运行期间的基础数据结构,存储局部变量表,操作数栈,动态链接,方法出口,当方法调用结束,帧才会被销毁。)。

线程共享:元空间MetaSpace,常量池的Java堆。

MetaSpace相比PermGen的区别:

  字符串常量池存在永久代中,可能有性能问题或内存溢出的风险.

  类和方法的大小比较难确定其大小,所以对永久代大小空间在指定带来困难.

  永久代会为gc带来不必要的复杂性

JVM三大性能调优参数: -Xms -Xmx-Xss的含义:

-Xss: 定义了每个线程虚拟机栈(堆栈)的大小,即并发线程数的大小.

-Xms:堆的初始值.

-Xmx:堆能达到的最大值.

java内存模型中堆和栈的区别:

  管理方式:栈自动释放,堆需要GC处理

  空间大小:栈比堆小

  碎片相关:栈产生的碎片原小于堆

  空间的分配方式:栈支持静态和动态,而堆仅支持动态的分配方式

  效率:栈的效率比堆高

原文地址:https://www.cnblogs.com/niuyg928/p/15183017.html