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

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

不良代码:

[java]  view plain copy
  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 plain copy
  1. //测试用的代码  
  2. Map m = new HashMap();  
  3. m.put("a""1");  
  4.   
  5. //比较好的代码  
  6. String s = (String) m.get("a");  

比较好的代码2

[java]  view plain copy
  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对象互相转换的。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值