运行愈来愈快的Java热点代码

2022年01月15日 阅读数:1
这篇文章主要向大家介绍运行愈来愈快的Java热点代码,主要内容包括基础应用、实用技巧、原理机制等方面,希望对大家有所帮助。

对于程序来讲,一般只有一部分代码会被常常执行,而应用的性能主要取决于这些代码执行得有多快。这些关键代码段被称为应用的热点代码,代码执行得越多就被认为是越热。dom

所以JVM执行代码时,并不会无脑编译代码。第一,若是代码只执行一次,那编译彻底就是浪费精力。对于只执行一次的代码,解释执行Java字节码比先编译而后执行的速度快。但若是代码是常常被调用的方法,编译就值得了:编译的代码更快,屡次执行累积节约的时间远超过了编译所花费的时间。ide

这种权衡是编译器先解释执行代码的缘由之一:编译器能够找出哪一个方法被调用得足够频繁,能够进行编译。第二个理由是为了优化: JVM执行特定方法或者循环的次数越多,它就会越了解这段代码。这使得JVM能够在编译代码时进行大量优化。性能

测试Demo1,运行彻底如出一辙的代码,性能大概提高了为原来的1/16:测试

package com.fun


import com.fun.frame.SourceCode

class TSSS extends SourceCode {


public static void main(String[] args) {

def mark0 = getNanoMark();
100.times {
getPercent(23, 17)
}
def mark1 = getNanoMark()
output(getFormatNumber(mark1 - mark0))


def mark10 = getNanoMark();
100.times {
getPercent(23, 17)
}
def mark11 = getNanoMark()
output(getFormatNumber(mark11 - mark10))


}


}

控制台输出:优化

INFO-> 当前用户:fv,IP:192.168.0.100,工做目录:/Users/fv/Documents/workspace/fun/,系统编码格式:UTF-8,系统Mac OS X版本:10.15.3
INFO-> 161,422,326
INFO-> 10,559,361

Process finished with exit code 0

测试Demo2,运行相同的方法,随机的参数,性能提高为原来的1/2:编码

package com.fun


import com.fun.frame.SourceCode

class TSSS extends SourceCode {


public static void main(String[] args) {

def mark0 = getNanoMark();
100.times {
getPercent(getRandomInt(100), getRandomInt(30))
}
def mark1 = getNanoMark()
output(getFormatNumber(mark1 - mark0))


def mark10 = getNanoMark();
100.times {
getPercent(getRandomInt(100), getRandomInt(30))
}
def mark11 = getNanoMark()
output(getFormatNumber(mark11 - mark10))


}


}

控制台输出:spa

INFO-> 当前用户:fv,IP:192.168.0.100,工做目录:/Users/fv/Documents/workspace/fun/,系统编码格式:UTF-8,系统Mac OS X版本:10.15.3
INFO-> 197,810,630
INFO-> 9,012,579

Process finished with exit code 0