编码时的一些建议

1、尽量指定类、方法的final修饰符——虚拟机会想办法内联所有的final方法来减少方法执行时创建栈帧的数量,从而降低栈溢出的风险

2、尽量重用对象——重复new对象会增加内存溢出的风险

3、尽可能使用局部变量—— 一些局部变量是在栈中,免了垃圾回收过程

4、及时关闭流——资源浪费问题

5、尽量减少对变量的重复计算——list.size()在循环中的处理,如果list很多计算多次很耗性能

6、尽量采用懒加载的策略——即在需要的时候才创建,还是创建对象问题,比如在if块外创建了对象

7、慎用异常——异常只能用于错误处理,不应该用来控制程序流程。因为异常有自己的异常对象,会占用堆空间

8、不要在循环中使用try…catch…,应该把其放在最外层——因为异常有自己的异常对象,会占用堆空间

9、如果能估计到待添加的内容长度,为底层以数组方式实现的集合、工具类指定初始长度,new HashMap(256),StringBuilder(int size)——因为集合的容量是随着元素的增多成本的扩容的

10、当复制大量数据时,使用System.arraycopy()命令,采用native

11、乘法和除法使用移位操作,乘法:<<,除法:>>——因为位运算是更接近计算机底层原理的,性能更高

12、循环内不要不断创建对象引用,Object obj = null; for (int i = 0; i <= count; i++) { obj = new Object(); }——因为对象是占用堆空间的,在循环里面new对象,容易导致内存溢出

13、基于效率和类型检查的考虑,应该尽可能使用array,无法确定数组大小时才使用ArrayList——因为集合的容量是随着元素的增多成本的扩容的

14、尽量使用HashMap、ArrayList、StringBuilder,除非线程安全需要,否则不推荐使用Hashtable、Vector、StringBuffer——后三者由于使用同步机制而导致了性能开销

15、不要将数组声明为public static final——public不安全,而final没有用

16、尽量在合适的场合使用单例——节省加载开销

17、尽量避免随意使用静态变量——gc通常是不会回收, public class A{ private static B b = new B(); },B会在A清除后才清除

18、及时清除不再需要的会话——HttpSession的invalidate()方法清除会话。

19、实现RandomAccess接口的集合比如ArrayList,应当使用最普通的for循环而不是foreach循环来遍历——假如是随机访问的,使用普通for循环效率将高于使用foreach循环;反过来,如果是顺序访问的,则使用Iterator会效率更高

20、使用同步代码块替代同步方法

21、将常量声明为static final,并以大写命名——程序启动的时候会主动加载到常量池

22、不要创建一些不使用的对象,不要导入一些不使用的类——not use的警告,可以清除

23、程序运行过程中避免使用反射——尽量在启动时就反射完成,大家不关心启动花了多长时间

24、使用数据库连接池和线程池——这个都有了,可以使用的连接池:c3p0,dbcp…

25、使用带缓冲的输入输出流进行IO操作——即BufferedReader、BufferedWriter、BufferedInputStream、BufferedOutputStream,提升IO效率

26、顺序插入和随机访问比较多的场景使用ArrayList,元素删除和中间插入比较多的场景使用LinkedList

27、不要让public方法中有太多的形参——能用类就用类,不要直接使用属性

28、字符串变量和字符串常量equals的时候将字符串常量写在前面

29、请知道,在java中if (i == 1)和if (1 == i)是没有区别的,但从阅读习惯上讲,建议使用前者

30、不要对数组使用toString()方法——输出没有意义

31、不要对超出范围的基本数据类型做向下强制转型——长整型不适合强转为整型数

32、公用的集合类中不使用的数据一定要及时remove掉——因为内存泄漏问题

33、把一个基本数据类型转为字符串,基本数据类型.toString()是最快的方式、String.valueOf(数据)次之、数据+”"最慢

34、使用最有效率的方式去遍历Map——iterator接口

35、对资源的close()建议分开操作——分开关闭不同的资源,避免未释放,如程序出现异常会导致后面的资源未释放,所以最好把资源释放放在finally中保证一定会被释放

36、JDK7中新引入的Objects工具类,对象比较

37、避免使用正则表达式,使用Apache Commons Lang作为代替

38、远离递归.递归会占用大量资源!

39、避免Random实例被多线程使用,虽然共享该实例是线程安全的,但会因竞争同一seed 导致的性能下降,JDK7之后,可以使用ThreadLocalRandom来获取随机数

40、静态类、单例类、工厂类将它们的构造函数置为private

41、提前编译正则表达式

42、尽可能地缓存

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值