JVM-基础

  • JVM内存结构:程序计数器、堆、栈、方法区、直接内存,运行时常量池的区别

程序计数器:是一块较小的内存空间,可以把它看成是当前线程所执行的字节码的行号指示器,字节码解释器就是通过改变计数器的值来选取下一条需要执行的字节码指令。Java虚拟机的多线程是通过线程轮流切换并分配处理器执行时间的方式来实现的,任何时间,一个处理器都只会执行一条线程,因此为了线程切换后能恢复到正确的位置,每个线程都需要一个独立的程序计数器,各条线程之间计数器互补影响,独立存储,所以是“线程私有”的内存。是唯一一个没有规定任何内存泄露的区域

:栈分为Java虚拟机栈和本地方法栈,也是线程私有

       Java虚拟机栈:存放局部变量表,局部变量表存放了各种基本数据类型,对象引用类型

       本地方法栈:Native方法服务

:线程共享,存放对象实例

方法区:线程共享,存储虚拟机加载的类信息、常量、静态变量

运行时常量池:存放编译期生成的各种字面量和符号引用

直接内存:JDK1.4中引用NIO类,使用Native函数库直接分配堆外内存,然后通过一个存储在Java堆中的DirectByteBuffer对象作为这块内存的引用进行操作

  • Java内存模型内存可见性、重排序、顺序一致性、volatile、锁、final

https://blog.csdn.net/qq_31997407/article/details/79705767

  • 垃圾收集器

参考《深入理解JVM虚拟机》第三章,垃圾收集器与内存分配策略

  • JVM参数及调优

https://blog.csdn.net/a_dreaming_fish/article/details/51208527

https://blog.csdn.net/baidu_39299382/article/details/80330311

  • Java对象模型:oop-klass,对象头

https://blog.csdn.net/baidu_39299382/article/details/80330399

  • HotSpot:即时编译器、编译优化

https://blog.csdn.net/qq_26807245/article/details/80841051

  • 类加载机制:classLoader、类加载过程、双亲委派(破坏双亲委派)、模块化(jboss modules、osgi、jigsaw)

https://blog.csdn.net/baidu_39299382/article/details/80330442

  • 虚拟机性能监控与故障处理工具:jps, jstack, jmap、jstat, jconsole, jinfo, jhat, javap, btrace、TProfiler

https://blog.csdn.net/baidu_39299382/article/details/80330476

  • 编译与反编译 : javac,javap,jad,crf

https://blog.csdn.net/baidu_39299382/article/details/80330538

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值