博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
《Effective Java》第八章:日常编程的一些小建议
阅读量:7061 次
发布时间:2019-06-28

本文共 2133 字,大约阅读时间需要 7 分钟。

hot3.png

1.最小化局部变量的作用域

  最小化局部变量的作用域有助于增加代码的可读性和可维护性,同时降低犯错的可能性;

  最好的最小化局部变量的作用域的方法就是:在第一次使用该变量的时候声明它。

2.用for-each循环替代传统的循环

  在Java5以前,循环都是这种形式的:

for (int i = 0; i < a.length; i++) {    doSomething(a[i]);}

 但是在5之后,你可以写成下面的形式:

for (Element e : elements) {    doSomething(e);}

  Java8发布以后,你还可以这样写:

a.forEach(a -> doSomthing(a));

详细的性能测试可以参考下面的文章:

不要被标题吓到了,使用java8的lambda显得比较慢的原因是因为第一次初始化的开销,事实证明,使用后两种循环方案不仅性能比第一种好,而且可读性更好,编写的代码也更少。第一种方案每次循环的边界检查会带来额外的开销,除非你确切的需要数组的下标,不要使用第一种循环。

3.了解并使用现有的库

4.如果需要知道确切的答案,不要使用float和double

  常见的就是涉及到钱的运算,JDK内置了BigDecimal类来支持这种运算,在加减乘除的过程中,BigDecimal能够让你完全控制小数点的取舍,在一般的情况下也不会带来太大的性能损失。使用浮点型会带来一些计算的黑洞。

5.优先使用基本型而不是包装类型

  使用基本类型运算上会带来更高的性能,也不会有空指针异常。自动拆装箱虽然是很好的语法糖,但是在某些情况下甚至会带来数十倍的性能差距。同时,也会引发空指针,(Integer) == (Integer)这种常见的BUG。

6.如果别的表示类型的方法更适用,就不要使用String

  试着使用enum或者泛型。

7.对于字符串连接操作的性能有所了解

  Java唯一重载了的运算符‘+’在连接字符串的时候特别方便,但是这个操作符每执行一次,就会创建一个新的字符串对象。在性能要求不高的场合这样很方便,但在性能敏感或者字符串数目较多的场合,推荐使用StringBuilder(它相比于StringBuffer不是线程安全的,但大部分字符串连接操作都是线程内部的,不需要线程安全,StringBuffer由于同步带来的性能原因已经不再被推荐使用)。

8.相对于反射,优先使用接口

  反射给了你对一个类运行时的控制机会,但是它有一些缺点:

  • 编译时期的类型检查带来的好处你一个也享受不到
  • 反射的代码不直观,容易犯错
  • 反射的代码无法做编译器优化(如JIT),带来的性能损失甚至是百十倍的

作为一条规则,一般的对象在通常的应用场景下在运行时不应该通过反射进行获取。

9.谨慎地使用native方法

  现在,已经不怎么建议使用native方法来改善性能了,在早期版本的JVM上,也许这样做是必要的,但现代的JVM所做的编译器优化在很多下已经能够媲美native code了;相反的,如果你使用native method,不但增加了项目复杂度,而且将牺牲掉Java跨平台的特性,如果不是对内存有足够的了解,带来的OOM也将是灾难性的。

  并不是说不要使用native方法,只是希望你能在使用native方法之前,仔细权衡,三思而后行。

10.谨慎地优化

More computing sins are committed in the name of efficiency (without necessarily achieving it) than for any other single reason—including blind stupidity.—William A. Wulf [Wulf72]//美其名曰的“为了性能”(然而实际上并没有达到这个目标)带来的罪恶超过包括盲目和无知在内的其它任何理由We should forget about small efficiencies, say about 97% of the time: premature optimization is the root of all evil.—Donald E. Knuth [Knuth74]//在97%的情况下我们应该忘掉那些小性能:优化是万恶之本We follow two rules in the matter of optimization:Rule 1. Don’t do it.Rule 2 (for experts only). Don’t do it yet—that is, not until you have aperfectly clear and unoptimized solution.—M. A. Jackson [Jackson75]//在优化方面我们遵循两条原则://原则1. 不做优化;//原则2.(仅仅针对专家). 暂时不要做-----这是说,在你有一个完美的清晰的未经优化的解决方案之前.

 

转载于:https://my.oschina.net/u/2541538/blog/1359243

你可能感兴趣的文章
关于字符串的一些操作
查看>>
无法访问磁盘提示无法访问的文件寻回方案
查看>>
计算机来当球赛战术分析员 看看它们怎么演算的
查看>>
C#中的webBrowser空间 连接InvokeMember("click") 无效问题
查看>>
整合spring cloud云服务架构 - eureka 基础
查看>>
区块链vs传统数据库:分布式运行有何优势?
查看>>
交换机原理
查看>>
TCP三次握手和四次挥手
查看>>
Spring Clould负载均衡重要组件:Ribbon中重要类的用法
查看>>
如何对flv视频进行压缩,3种方法教你搞定
查看>>
嵌入式软件开发学习 工程师要掌握的基本技能
查看>>
Linux / CentOS 7 编译安装http服务
查看>>
云计算面试题及答案,云计算工程师面试题集锦
查看>>
Another mysql daemon already running with the same unix socket
查看>>
view
查看>>
来自一个女司的无人驾驶体验测评,了解一下
查看>>
微信中直接打开手机系统浏览器的实现
查看>>
powershell 命令服务器获取硬件信息
查看>>
ORACLE 深入解析10053事件
查看>>
js获取网页屏幕可见区域高度
查看>>