博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
JVM虚拟机
阅读量:7219 次
发布时间:2019-06-29

本文共 1094 字,大约阅读时间需要 3 分钟。

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
image.png

转载地址:http://rexym.baihongyu.com/

你可能感兴趣的文章
网络安全是一种态度
查看>>
POJ1131 Octal Fractions
查看>>
mysql-ulogd2.sql
查看>>
119. Pascal's Triangle II - Easy
查看>>
349. Intersection of Two Arrays - Easy
查看>>
[算法练习]最长公共子串(LCS)
查看>>
p转c++
查看>>
树(tree)
查看>>
codevs——2645 Spore
查看>>
ssh服务之 远程登录和端口转发
查看>>
java环境配置正确,但是tomcat不能启动的解决办法
查看>>
我就是想找个人聊聊天,说说我这近四年来的经历
查看>>
不同的测试方法使用的场景
查看>>
Hadoop快速入门
查看>>
Problem S
查看>>
SVN上传的时候没法显示文件名,只显示后缀名
查看>>
Python:pygame游戏编程之旅四(游戏界面文字处理)
查看>>
fedroa 编译安装mysql5.5
查看>>
WC2018游记
查看>>
毕设开发日志2017-10-23
查看>>