JVM的性能优化(下)

GC的调优工具 :jstat 主要针对于GC的java

经过Dos命令运行 D:\compile\worker.java浏览器

从新开启一个Dos窗口安全

jstat-class2041(java程序的pid值)  :查看加载了多少个类多线程

jstat -compiler 2041   :查看编译的状况并发

jstat -gc 2041 查看垃圾的回收统计工具

jstat -gc 2041 1000 5 1秒打印一次总共打印5次this

GC的调优工具 jmap :主要针对于内存使用状况的线程

1)经过 Dos 命令运行 D:\compile\Worker.javaorm

2)从新开启一个Dos窗口对象

jmap-heap 2041(java程序的PID值)   //查看内存使用状况

jmap -histo 2041 |more //查看内存中对象数量及大小

jamp -dump:format=b,file=d:/test/dump.dat 2041  //将内存使用状况dump到文件中

jhat -port 9999 d:/test/dump.dat     //经过jhat对dump文件进行分析 端口号能够自定义 而后在浏览器中经过 127.0.0.1:9999就能够访问了.

GC的调优工具 jstack  :主要针对于线程

1)线程的六种状态:

新建,就绪,运行(运行的时候会发生等待或者阻塞),死亡

2)经过jstack命令能够查看java的程序状态

jstack 2041(Java程序的pid值)

GC的可视化调优工具

本地调优:该工具位于JDK安装目录 /bin/jvisualvm.exe //双击能够直接使用

该工具涵盖了上述全部命令

远程调优:

JVM的线程安全与锁的俩种形式

线程安全:多线程,并发,操做统一数据 就可能引起安全问题 须要用到"同步"解决

"同步"分类:

同步代码块:

     格式:

synchronized (锁对象){

//要加锁的代码

}

注意:1)同步代码块的锁对象能够是任意类型的对象

        2)必须使用同一把锁 否侧可能出现锁不住的状况

同步方法:

静态同步方法:

锁对象是:该类的字节码文件对象

非静态同步方法:锁对象是this

Lock 锁

1)LOCK锁和synchronized的区别

1.1) synchronized 是java内置的语言,是java的关键字

1.2)synchronized 不须要手动区去释放锁 当synchronized方法或者synchronized代码块执行完毕后 系统会自动释放该对象锁的占用

而lock必须手动释放锁,若是没有主动释放锁,就有可能形成死锁的问题

示例代码

相关文章
相关标签/搜索