Effective Java 第三版——66. 明智谨慎地使用本地方法

Tips
书中的源代码地址:https://github.com/jbloch/effective-java-3e-source-code
注意,书中的有些代码里方法是基于Java 9 API中的,因此JDK 最好下载 JDK 9以上的版本。java

Effective Java, Third Edition

66. 明智谨慎地使用本地方法

Java Native Interface(JNI)容许Java程序调用本地方法(native methods),这些方法是用本地编程语言(如C或C ++)编写的方法。 从历史上看,本地方法有三个主要用途。 它们提供对特定于平台设备(如注册表)的访问。 它们提供对现有本地代码库的访问,包括提供对遗留数据库的数据访问。 最后,本地方法用于以本地语言编写应用程序的性能关键部分,以提升性能。git

如今已经再也不建议使用本地方法来提升性能。 在早期版本(Java 3以前)中,它一般是必需的,但从那时起JVM就变得更快了。 对于大多数任务,如今能够在Java中得到可比较的性能。 例如,当在Java版本1.1中添加java.math时,BigInteger依赖于用C语言编写的一个快速多精度算术库。在Java 3中,BigInteger在Java中从新实现,并仔细调整到比原始本地实现运行得更快的程度。程序员

这个故事的一个可悲的结尾是,除了在Java 8中对大数进行更快的乘法运算以外,BigInteger此后几乎没有发生什么变化。在此期间,对本地类库的工做继续快速进行,尤为是GNU多精度算术类库(GMP)。若是须要真正高性能多精度算法,Java程序员如今能够经过本地方法使用GMP [Blum14]。github

使用本地方法具备严重的缺点。 因为本地语言不安全(条目50),使用本地方法的应用程序再也不免受内存损坏错误的影响。 因为本地语言比Java更依赖于平台,所以使用本地方法的程序不太可移植。 它们也更难调试。 若是使用不当,本地方法可能会下降性能,由于垃圾收集器没法自动甚至跟踪本地内存使用状况(条目 8),而且存在进入和退出本地代码相关的成本。 最后,本地方法须要“粘合代码”,难以阅读,编写还繁琐。算法

总之,在使用本地方法以前要三思然后行。 不多须要使用它们来提升性能。 若是必须使用本地方法来访问地城资源或本地类库,请尽量少地使用本地代码,并对其进行完全测试。 本地代码中的单个错误可能会破坏整个应用程序。数据库

相关文章
相关标签/搜索