(1)运行期优化-逃逸分析
data:image/s3,"s3://crabby-images/57189/571897f39b48162b99553e5b79047c2d8b11480b" alt=""
在运行期间java虚拟机会对我们代码做一些优化,时间会变短:
data:image/s3,"s3://crabby-images/2fa19/2fa19f683488ad6056334a9dc03d2ad2de08e4e1" alt=""
data:image/s3,"s3://crabby-images/76507/76507b86d45f717af2005ce5523772b77ad1291b" alt=""
data:image/s3,"s3://crabby-images/1fa43/1fa43e6975e57bb130d4402f46356f9fdec3f859" alt=""
字节码反复调用,到达一定的阈值,会启用编译器对自己饿吗编译执行,从0层上升为1层C1
C1和C2他俩的区别是解释程度不一样 ,C2执行更特殊的优化
data:image/s3,"s3://crabby-images/12f2c/12f2cc2024ae9995a78e99c48aa85bc58ead19f9" alt=""
data:image/s3,"s3://crabby-images/04318/04318eaaf23b21c607c5cec2a463f80614e9c592" alt=""
data:image/s3,"s3://crabby-images/b648d/b648df1b357830b899d2db4a7660bcc2c16418b8" alt=""
逃逸分析回去分析new Object对象会不会在循环外用到,被其他方法所引用,发现创建对象不会被逃逸,逃逸分析后在C2里做了优化后,会把对象的创建的字节码替换掉,干脆不会创建对象了,速度会提升很快
data:image/s3,"s3://crabby-images/1a9e4/1a9e4fe58576bb9c8e7ff3f1067f794b21372b77" alt=""
关闭逃逸分析后时间没有降到3位数,关闭逃逸分析,它就没有达到c2的编译器编译了
data:image/s3,"s3://crabby-images/1e0a0/1e0a032dd59a38e50dfbc0bda20ca7dcc5155ddd" alt=""
(2)运行期优化-方法内联
方法内联属于及时编译器的一种
data:image/s3,"s3://crabby-images/41b08/41b08f0e0fb9c0c1a69a7233e474f1309e1990eb" alt=""
data:image/s3,"s3://crabby-images/cba38/cba38fc733ad10cdaf2ed153c455c7dd04898e5e" alt=""
七十多次变成4位数,两百多次变为0秒了,因为他已经内联了,内联之后呢根本就没有方法调用了,第一次计算出来是81,第二次计算出来还是81,就会认为是常量,没有必要在计算了为0了
data:image/s3,"s3://crabby-images/327dd/327ddfc84f60fa454914b90250b9d52f5b84eb89" alt=""
data:image/s3,"s3://crabby-images/24f3e/24f3e248d2915a4c9f5af1e57e84f3bfb385f8d1" alt=""
data:image/s3,"s3://crabby-images/17916/179160efdedb3e091e14b31d06f2c8c2f218b510" alt=""
通过参数设置打印哪些方法进行了内联 :包含很多jdk方法的内联,和我们定义方法的内联
data:image/s3,"s3://crabby-images/bcb47/bcb4714ead25a3b1db79d13e21467b32b9b20527" alt=""
data:image/s3,"s3://crabby-images/2dbdd/2dbdd781feb02b2c9a3609c33805d81590682b0d" alt=""
还可以禁用某个内联:
data:image/s3,"s3://crabby-images/ef355/ef35554c5c2598099a4ae7917715c3116bd4c524" alt=""
关闭之后不会下降到0了
(3)运行期优化-字段优化
字段优化是针对成员变量,静态成员变量读写操作的优化
我们使用JMH
data:image/s3,"s3://crabby-images/cc64f/cc64fe13f4a0084596b33640739178d86c22e8b6" alt=""
data:image/s3,"s3://crabby-images/db0e4/db0e46e164a188d8b8d5d1cb98209708b3dae6a2" alt=""
data:image/s3,"s3://crabby-images/47f89/47f898b6918c4302cf33fca7bd0303ac7816be07" alt=""
doSum方法上加注解,是否禁止方法内联
data:image/s3,"s3://crabby-images/fe0bf/fe0bfb7c9e0654ebe46f29d8f1bd1d8870636aa9" alt=""
我们只要看Score吞吐量的得分,他们是差不多的
下面我们关闭方法内联修改注解:
data:image/s3,"s3://crabby-images/280ae/280aec02baed5f013f1e73e27f9d43563bd218a7" alt=""
得分 下降了
test3根test2的字节码是等价的
data:image/s3,"s3://crabby-images/28894/2889467084127a4d58f54c93a1946da49d38a69d" alt=""
data:image/s3,"s3://crabby-images/afb46/afb460172da4d5e7c76b09986af7e3b525bd2dff" alt=""
data:image/s3,"s3://crabby-images/09714/097147299f914c9d9795ef8149c44513f60c054d" alt=""
test2是手动做的优化,test1是由虚拟机帮祝我们优化,如果想要自己做优化的话尽可能使用局部变量,不要使用成员变量,静态变量
(4)反射优化
data:image/s3,"s3://crabby-images/d86cd/d86cdf8989dfe5d945e340c243d1960cd6fbaaf5" alt=""
data:image/s3,"s3://crabby-images/f7381/f73815cb0a8deebc0b387c19edd88b8e8b0ca312" alt=""
data:image/s3,"s3://crabby-images/30ab5/30ab5e07669d7a6c39b3a41850c1fb0fecb21661" alt=""
data:image/s3,"s3://crabby-images/bb40d/bb40def9e0c9d4c05053b08896b34059427765e5" alt=""
方法实现 :invoke0是native方法是本地方法它的实现代码是C++实现的java这边呢只是对它做了一个调用本地方法的性能调用起来是非常低的,前0-15次调用的都是本地方法,16次性能会变高
data:image/s3,"s3://crabby-images/62615/6261569873a5d453f3b0303b52537ad8b24548b0" alt=""
data:image/s3,"s3://crabby-images/40a51/40a511680f72cdcf40b836babd42f8f414d6da29" alt=""
第16次会动态生成新的方法访问器类,在运行期间动态生成的,没有源代码
我们通过一个工具查看
data:image/s3,"s3://crabby-images/1f22c/1f22ca8b8dfdf7ecdbf054657b0f0726d81828fb" alt=""
首先知道生成类的名字
data:image/s3,"s3://crabby-images/95622/95622af843bbc81c302a3e42d0f33160d4fa82fb" alt=""
data:image/s3,"s3://crabby-images/80da4/80da4106561472cd3df8493fa5bafbdf8fabda57" alt=""
data:image/s3,"s3://crabby-images/142ab/142ab0b773193e45cfcef571603972141b1fc3a0" alt=""
反编译动态生成的类:
第16次把方法反射调用转换成了正常方法调用
data:image/s3,"s3://crabby-images/f1b2b/f1b2b5cb190ca8fbc671c94117960b5abcb3e24b" alt=""
data:image/s3,"s3://crabby-images/a8ff2/a8ff2e86d380306e2188edbcaea2714a0f0c1c69" alt=""
data:image/s3,"s3://crabby-images/89767/89767c6df089cf434fe25a910685a954832b480b" alt=""