最近在写一个项目的代码,review的时候发现了一些问题,是需要积累和总结的经难,帮总结如下:
1.Map的遍历
以前对Map的遍历,都使用EntrySet,其实有更好的方式,代码如下:
public class Test {
public static void main(String[] args) {
Map<String, String> map = new HashMap<String, String>();
map.put("arg1", "hello1");
map.put("arg2", "hello2");
map.put("arg3", "hello3");
Collection<String> keys = map.keySet();
for(String key : keys) {
String val = map.get(key);
System.out.println("key=" + key + ",value=" + val);
}
}
}
2. 数组的问题
字符串需要split时,split里的参数是正则表达式,比如字符串d|test|1234,需要split,代码应该写成:
String str = "p|test|1234";
String args[] = str.split("\\|");
这样写的代码,生成的字符数组长度为3。
另外,对数组的取值时,比如上例中需要取args[2],则需要对数组的长度进行判断,否则会出现越界的情况而报错。
3.全局变量与局部变量
如果代码里有共享的部分,那么需要写成全局变量。全局变量就需要考虑并发安全的问题。
如果是局部变量,那就不需要考虑。
比如HashMap这种类型就不是线程安全的,用作全局变量不合适。如果有并发问题,需要使用CurrentHashMap,但是这种线程安全的类肯定是有性能开销的。