首頁 >Java >java教程 >比較foreach和for的差別

比較foreach和for的差別

巴扎黑
巴扎黑原創
2017-09-05 14:06:202935瀏覽

下面小編就為大家帶來一篇老生常談foreach(增強for迴圈)和for的差別。小編覺得蠻不錯的,現在就分享給大家,也給大家做個參考。一起跟著小編過來看看吧

先說foreach有的也叫增強for循環,foreach其實是for循環的一個特殊簡化版。

再說一下foreach的書寫格式:

for(元素類型  元素名稱: 遍歷陣列(集合)(或能進行迭代的) ){

語句

 }

foreach雖然是for迴圈的簡化版本,但是並不是說foreach就比for更好用,foreach適用於迴圈次數未知,或是計算迴圈次數比較麻煩情況下使用效率更高,但更為複雜的某些迴圈還是需要用到for迴圈效率更高。

我們看看下面的範例:


#
public static void main(String[] args) {
  List<String> arr = new ArrayList<String>();
  arr.add("你好");
  arr.add("我好");
  arr.add("大家好");
  
  //foreach循环
  for(String str : arr){       //这里的str就是为了获取每次循环的arr中的值
   System.out.println(str);       //就相当于 String str=arr[i]
  }
 }

但是相比較之下我們用for循環輸入就略顯麻煩


public static void main(String[] args) {
  List<String> arr = new ArrayList<String>();
  arr.add("你好");
  arr.add("我好");
  arr.add("大家好");
  
  //for循环
  for(int i=0;i<arr.size();i++){
   System.out.println(arr.get(i)); //要获取list中元素需要用get方法 
  }
 }

除了這種普通的集合還可以物件map這種鍵值對使用

例如:


public static void main(String[] args) {
  Map<String,String> mapstr = new HashMap<String,String>();
  mapstr.put("王", "男");
  mapstr.put("李", "男");
  mapstr.put("张", "女");
                      //entrySet方法是为了获取键值对的集合
  for(Map.Entry<String, String> s : mapstr.entrySet()){ //这里的Map.Entry<String, String>其实就是一个类型 用来表示键值对的类型
   System.out.println("key="+s.getKey());   //这里其实还是相当于 s=maostr.entrySet,只不过s存储的是键值对。
   System.out.println("value="+s.getValue());  //所以可以用get方法获取出来存储的键值对。
  }
 }

另外foreach不支援在迴圈中新增刪除操作,因為在使用foreach迴圈的時候數組(集合)就已經被鎖定不能被修改,否則會報出java .util.ConcurrentModificationException異常

例如:


public static void main(String[] args) {
  List<String> arr = new ArrayList<String>();
  arr.add("你好");
  arr.add("我好");
  arr.add("大家好");
  
  //foreach循环
  for(String str : arr){     
   System.out.println(str);   
   arr.add("1");     //对arr进行添加 
  }
 }

關於不能添加刪除原理以及如何在foreach中添加刪除我們下篇再說。

所以總結如下:

foreach適用於只是進行集合或陣列遍歷,for則在較複雜的迴圈中效率更高。

foreach不能對陣列或集合進行修改(新增刪除操作),如果想要修改就要用for迴圈。

所以相比較下來for迴圈比較為靈活。

以上是比較foreach和for的差別的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn