ava 程序员如何写出优美代码, 请往下看:
1 注释尽可能全面
对于方法的注释应该包含详细的入参和结果说明, 有异常抛出的情况也要详细叙述; 类的注释应该包含类的功能说明作者和修改者
2 多次使用的相同变量最好归纳成常量
多处使用的相同值的变量应该尽量归纳为一个常量, 方便日后的维护
3 尽量少的在循环中执行方法调用
尽量在循环中少做一些可避免的方法调用, 这样可以节省方法栈的创建例如:
1.for(inti=0;i
4 常量的定义可以放到接口中
在 Java 中, 接口里只允许存在常量, 因此把常量放到接口中声明就可以省去 public static final 这几个关键词
5ArrayList 和 LinkedList 的选择
这个问题比较常见通常程序员最好能够对 list 的使用场景做出评估, 然后根据特性作出选择 ArrayList 底层是使用数组实现的, 因此随机读取数据会比 LinkedList 快很多, 而 LinkedList 是使用链表实现的, 新增和删除数据的速度比 ArrayList 快不少
6String,StringBuffer 和 StringBuilder
这个问题也比较常见在进行字符串拼接处理的时候, String 通常会产生多个对象, 而且将多个值缓存到常量池中例如:
1.Stringa="a"; 2.Stringb="b"; 3.a=a+b;
这种情况下 jvm 会产生 "a","b","ab" 三个对象而且字符串拼接的性能也很低因此通常需要做字符串处理的时候尽量采用 StringBuffer 和 StringBuilder 来
7 包装类和基本类型的选择
在代码中, 如果可以使用基本数据类型来做局部变量类型的话尽量使用基本数据类型, 因为基本类型的变量是存放在栈中的, 包装类的变量是在堆中, 栈的操作速度比堆快很多
8 尽早的将不再使用的变量引用赋给 null
这样做可以帮助 jvm 更快的进行内存回收当然很多人其实对这种做法并不感冒
9 在 finally 块中对资源进行释放
典型的场景是使用 io 流的时候, 不论是否出现异常最后都应该在 finally 中对流进行关闭
10 在 HashMap 中使用一个 Object 作为 key 时要注意如何区分 Object 是否相同
在 jdk 的 HashMap 实现中, 判断两个 Object 类型的 key 是否相同的标准是 hashcode 是否相同和 equals 方法的返回值如果业务上需要对两个数据相同的内存对象当作不同的 key 存储到 hashmap 中就要对 hashcode 和 equals 方法进行覆盖
来源: http://www.jianshu.com/p/3608d0170956