虚拟机性能监控
命令:
jps(jvm process status):展示虚拟机运行进程唯一ID和启动主类。
jstat:监视虚拟机各种状态运行信息,显示本地或远程虚拟机进程中的类加载、内存、垃圾收集、JIT收集等运行数据。用于查看运行期虚拟机性能问题首选。
jstack:java堆栈跟踪工具,用于生成当前虚拟机的线程快照。
工具:
在java文件的bin目录下,执行 jconsole.exe,可以打开客户端检测,堆栈使用内存情况和线程启动、死锁情况。
VisualVM工具,先对更加齐全的检测工具。
JVM类文件结构和加载机制
JVM虚拟机定向为:让其他语言运行之上成为可能。
类加载分为七大步骤:
加载 - 验证 - 准备 - 解析 - 初始化 - 使用 - 卸载
加载例子:
当通过子类调用父类静态值,不会触发子类初始化,只会初始化父类。
当通过类调用本类常量(final),不会触发类初始化。加载时,会直接将常量防止在常量池,不与本类发生关系。
运行时栈帧结构:
编译时,已经确定局部变量表需要内存分配。运行中,只有栈顶的数据才是有效的。
方法调用:
定义一个类,和实现一个类,存在不同的加载周期。定义在编译时已经确定,实现的具体,需要在运行时才能确定。称为:静态类型和实际类型。A a = new B(); 其中B可以继承实现A。
加载例子(重载):
例1:当A为父类,分别实现 B和C类;同时实现A中的say()方法;调用时:A b = new B();A c = new C();b.say();c.say();其结果是:都执行A中返回值,不会触发B、C中的方法。
例2:当main中执行change(‘a’);在类中有多个重载的静态change方法,change(Object a);change(char a);change(int a);change(Character a);change(char… a);change(Serializable a); 会最先执行char参数方法,其次是 int ,Character 、Serializable(Character 的实现接口) 、Object 、char…
java中的泛型为 伪泛型,List< String > 最终编译会变成 List< E >。
apache等通用服务器加载jar时,采用不同模块,不同运用范围。
OSGi,运行时确定加载,可以灵活配置加载模块,可用于:服务特定模块停止,更新。
高效并发
java中特定关键字:volatile
1、保证线程间的可读性;但不保证写的一致;运用时,不可将标记变量参与运算,即可保证线程安全。
2、禁止指令重排序优化;一般java编写的代码,在进行编译的时候,只保证结果一致性,对于期间不相关的两个命令,执行顺序是不定的。但是用volatile标识的语句,指令顺序一致。
线程安全参照,先行发生原则,而非时间顺序原则。这个线程是一定发生后,下个线程再执行。而不是一个比这个先执行,就行。