不良代码展示-尽量强制转换减少toString()的调用

来源:互联网 发布:java word在线编辑 编辑:程序博客网 时间:2024/05/16 09:27

原文链接:http://blog.csdn.net/yihui823/article/details/6936284

不良代码:

[java] view plaincopy
  1. //测试用的代码  
  2. Map m = new HashMap();  
  3. m.put("a""1");  
  4.   
  5. //不良代码1  
  6. String s = m.get("a").toString();  
  7.   
  8. //不良代码2  
  9. int i = Integer.parseInt(m.get("a").toString());  


其实,Map里面存放的虽然是Object,但是放进去String对象,拿出来的还是String对象,是可以强制转换的。

而调用toString()方法,是有系统开销的,同样也会有NullPointException的危险。

而且,如果放入的对象可以明确是整数的话,最好还是不要放String,而是直接放Integer对象比较好。


比较好的代码1

[java] view plaincopy
  1. //测试用的代码  
  2. Map m = new HashMap();  
  3. m.put("a""1");  
  4.   
  5. //比较好的代码  
  6. String s = (String) m.get("a");  

比较好的代码2

[java] view plaincopy
  1. //测试用的代码  
  2. Map m = new HashMap();  
  3. m.put("a"new Integer(1));  
  4.   
  5. //比较好的代码2  
  6. int i = (Integer) m.get("a");  

java编译器会在合适的时候,自动把int类型和Integer对象互相转换的。