GC的调优工具 :jstat 主要针对于GC的
通过Dos命令运行 D:\compile\worker.java
重新开启一个Dos窗口
jstat-class2041(java程序的pid值) :查看加载了多少个类
jstat -compiler 2041 :查看编译的情况
jstat -gc 2041 查看垃圾的回收统计
jstat -gc 2041 1000 5 1秒打印一次总共打印5次
GC的调优工具 jmap :主要针对于内存使用情况的
1)通过 Dos 命令运行 D:\compile\Worker.java
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必须手动释放锁,如果没有主动释放锁,就有可能造成死锁的问题