java for循環的時候增加循環體的長度是不是不太好的?
問題描述
for(CityDataVO cityItem: citys){boolean flag =false;for(ProvinceDataVO proItem : list){ xxxxxx flag = true; break;}if(!flag){ ProvinceDataVO province = new ProvinceDataVO(); province.setProvinceId(cityItem.getProvinceId()); province.setProvinceName(cityItem.getProvinceName()); province.setReportNum(cityItem.getCount()); List<CityDataVO> vo = new ArrayList<>(); vo.add(cityItem); province.setCityData(vo); list.add(province);} }
比如上面的代碼,如果我沒有進入第二層的for循環里,我就會對list進行一個add的操作。這里應該是沒有問題的,因為我在第一個for循環體里操作的是第二個for循環的size()。我記得有一個情景是for(){...}我直接在...操作了for的size(),這樣好像是不行的,當初好像有一個什么辦法的,我暫時想不到了,哪位大神幫我回憶回憶呵??
問題解答
回答1:不要用 for(:){},用 for(int i = 0; i < list.size(); i++),小心不要搞成死循環
回答2:在for each,也就是你的代碼里 for(a : as)的循環中,不能對被循環集合進行增加或刪除操作,否則會報ConcurrentModificationException.在這段代碼里是沒有問題的。因為你改變list的操作都是在內層循環之外做的。
看你的需求其實就是按省統計各市的數據。有條件使用Java 8的話,可以看看Stream的GroupBy方法。可以大大簡化代碼。
一些不相太干的問題,set方法設置一個list的方式是不太合適的。
如果是有業務邏輯的對象,應該對內部結構進行包裝后以業務領域的概念提供接口,而不應該直接暴露內部的集合。
即便是數據傳遞對象,也不應該提供集合屬性的set方法。一般而言,私有集合變量的生命周期應該由它的父對象管理。外界通過外面包裝對象的add或remove方法操作私有的集合。如果需要提供集合方式的get方法。需要考慮是否要進行copy或者使之不可變。
回答3:不能在foreach里操作list(add,remove等操作)
回答4:希望直接跳出兩層循環,無非是兩種辦法:
用break label的語法(這個我從沒用過,可以Google一下);
就是你用的辦法,設個標志位。
另外,city的復數是cities而不是citys。
回答5:這寫得啰嗦了。我的話先這樣寫:
for (CityDataVO cityItem: citys){ if (validateCityItem(cityItem, list)) {continue; } List<CityDataVO> vo = new ArrayList<>(); vo.add(cityItem); ProvinceDataVO province = new ProvinceDataVO(); province.setProvinceId(cityItem.getProvinceId()); province.setProvinceName(cityItem.getProvinceName()); province.setReportNum(cityItem.getCount());province.setCityData(vo);list.add(province);}...private boolean validateCityItem(CityDataVO cityItem, List<ProvinceDataVO> list) { for(ProvinceDataVO proItem : list){if (...) { return true;} }return false;}
你的原代碼有幾個需要優化的地方:
盡量避免雙重循環,內循環一般都應該提取出來;
對同一個變量的操作,代碼行盡可能集中在一起,這樣閱讀起來更自然;
變量命名應當表現其業務含義和主要類型,比如 List 對象盡量都用 xxxList 方式命名。這我懶得給你改了。
回答6:不明白你到底問什么..是if進不去嗎?
回答7:提問前先組織好自己的思路,你想問的是什么?你希望得到什么回答?不然其他人幫不了你回答。
相關文章:
1. MYSQL 的 SELECT 語句中如何做到判斷字段為空2. .......3. javascript - H5頁面無縫輪播4. python - flask jinjia2 中怎么定義嵌套變量5. python - Django問題 ’WSGIRequest’ object has no attribute ’user’6. 數據庫 - mysql boolean型無法插入true7. javascript - URL中有#號如何來獲取參數??? nodejs8. centos - apache配置django報錯:cannot be loaded as Python modules9. javascript - jquery選擇的dom元素如何更新?10. html5 - 使用angular中,圖片上傳功能中選擇多張圖片是怎么實現的?有什么好的思路嗎?
