JVM虚拟机
Java内存结构和java内存模型的区别。往往很多人会搞起来。这里主要对这2种进行解释并进行操作。经实践会JVM调优和不会JVM调优差别确实很大,足足可以提升服务器一倍的性能。
java内存结构:所谓的堆,栈,方法区和本地方法栈
java内存模型:
image.png
image.png
image.png
image.png
image.png
image.png
这个堆栈分配在idea中设置的地方
image.png
新生代设置比较小的话,垃圾回收会频繁去回收,否则内存不够用,频繁回收又影响性能,不回收又会导致内存溢出,所以这个配比很关键
一般设置虚拟机内存大小都是为当前PC的内存大小,新生代和老年代的内存比例是1:2,一般老年代都会多点,因为这样可以减少垃圾回收的次数,提高性能。初始堆内存和最大堆内存设置一样。
内存溢出,有栈溢出和堆溢出,栈溢出就像下面的死循环,这个在栈当中申明的int最大只能到一定的数字
image.png
image.png
总结:jvm参数调优,主要设置堆内存,主要让gc不要去频繁去回收垃圾,减少对老年代的回收。
image.png
gc线程就是守护线程:主线程挂了,gc线程也挂了
非守护线程就是主线程挂了,但是new Thread依然在执行。
如果要把非守护线程变成守护线程,需要使用join,例:new Thread().setDeamon();
image.png
1.引用计算法
image.png
2.标记清除算法
image.png
3.复制算法。缺点是可用内存是原来内存的一半
image.png
4.标记压缩算法
image.png
5.GC分代算法
就是根据新生代和老年代进行垃圾回收,一般新生代回收的较多,老年代回收的较少,所以应该要避免老年代的gc回收,老年代回收比较慢
垃圾回收时的停顿现象
每次gc回收的时候,其他所有线程都会停顿,如果不停顿的话,那又有可能使用对象,或者新增对象,不便于垃圾清理。
垃圾收集器:
串行回收---单线程(单核回收)
并行回收---多线程(多核回收) 企业用的比较多,性能好
CMS回收---并行GC,用标记清除算法进行回收,性能是最好的,一般用并行回收就可以了
G1回收,是在jdk1.7提出来的,用的比较少
测试接口吞吐量
启动jmeter测试工具,压力测试工具,主要测试网站的吞吐量,就是每秒能被访问多少次
image.png
image.png
image.png
image.png
image.png