循环反思-for循环的滥用

本博刚刚从学校毕业,刚进去公司工作也已经接近两个月了。

最近我的pl分配了一个功能给我,主要涉及到了两个bean,然后两个bean都有一个projectID,然后我要做的就是通过匹配相同的projectID,把两个bean合并成一个bean反馈给前端,让前端显示相关功能。

一开始思路

for(int i = 0;i<bean1.size();i++){  
Bean1 bean = bean1.get(i);  
//do something  
for(j = 0;i<bean2.size();j++){  
if(baan.getProjectId==bean2.get(j).getProjectId)  
//do something  
}  



一开始的觉得不什么事,因为我测试的时候都是用小数据来测试,速度还算可以,但是一旦数据是大数据的时候,这个循环就坏了,比如bean1是万级别的,bean2也是万级别的,这个循环就等于是亿级别的,这个循环的话没半小时干不完。

因此,在后面我选择了用hashmap的entrySet方法,这样就能减少循环的次数,虽然也是万级别的,但是比亿级别快多了。

  1.   System.out.println("通过Map.entrySet遍历key和value");  
  2.   for (Map.Entry<String, String> entry : map.entrySet()) {  
  3.    System.out.println("key= " + entry.getKey() + " and value= " + entry.getValue());  
  4.   }  

当需要遍历hashmap的时候,请尽量使用entrySet,而不要用keySet,entrySet的效率要比keySet高,实际上使用 entrySet是只需要遍历一次hash,即将key和value的映射关系放入到entry中,再取之;而keySet需要两次遍历hash,第一次 取所有的key,第二次用key去取出对应的value。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值