java中用for做個循環(Java For循環)

本文目錄一覽:

java怎樣使用「for」語句無限循環?

Java中要使for語句無限循環,只需把循環的判定條件去掉即可。

實現for語句無限循環的方法有很多,最常用的就是直接在條件中寫兩個分號,如下代碼句所示:for(;;),這樣就達到了無限循環的目的。

其實開發中,最大忌諱就是使用無限循環,因為一旦控制不好就會出現死循環,如果在循環產生的對象較多,且又沒有及時處理,這樣就會導致內存泄漏,嚴重時就會導致系統直接崩潰。故開發慎用無限循環,尤其是一些無法停止的循環。

java for循環用法

Java for循環的幾種用法詳解

本文非常適合初學Java的程序員,主要是來了解一下Java中的幾種for循環用法,分析得十分詳細,一起來看看。

J2SE 1.5提供了另一種形式的for循環。藉助這種形式的for循環,可以用更簡單地方式來遍曆數組和Collection等類型的對象。本文介紹使用這種循環的具體方式,說明如何自行定義能被這樣遍歷的類,並解釋和這一機制的一些常見問題。

在Java程序中,要「逐一處理」――或者說,「遍歷」――某一個數組或Collection中的元素的時候,一般會使用一個for循環來實現(當 然,用其它種類的循環也不是不可以,只是不知道是因為for這個詞的長度比較短,還是因為for這個詞的含義和這種操作比較配,在這種時候for循環比其 它循環常用得多)。

對於遍曆數組,這個循環一般是採取這樣的寫法:

清單1:遍曆數組的傳統方式

/* 建立一個數組 */

int[] integers = {1, 2, 3, 4};

/* 開始遍歷 */

for (int j = 0; j integers.length; j++) {

int i = integers[j];

System.out.println(i);

}

而對於遍歷Collection對象,這個循環則通常是採用這樣的形式:

清單2:遍歷Collection對象的傳統方式

/* 建立一個Collection */

String[] strings = {“A”, “B”, “C”, “D”};

Collection stringList = java.util.Arrays.asList(strings);

/* 開始遍歷 */

for (Iterator itr = stringList.iterator(); itr.hasNext();) {

Object str = itr.next();

System.out.println(str);

}

而在Java語言的最新版本――J2SE 1.5中,引入了另一種形式的for循環。藉助這種形式的for循環,現在可以用一種更簡單地方式來進行遍歷的工作。

1、 第二種for循環

不嚴格的說,Java的第二種for循環基本是這樣的格式:

for (循環變數類型 循環變數名稱 : 要被遍歷的對象) 循環體

藉助這種語法,遍歷一個數組的操作就可以採取這樣的寫法:

清單3:遍曆數組的簡單方式

/* 建立一個數組 */

int[] integers = {1, 2, 3, 4};

/* 開始遍歷 */

for (int i : integers) {

System.out.println(i); /* 依次輸出「1」、「2」、「3」、「4」 */

}

這裡所用的for循環,會在編譯期間被看成是這樣的形式:

清單4:遍曆數組的簡單方式的等價代碼

/* 建立一個數組 */

int[] integers = {1, 2, 3, 4};

/* 開始遍歷 */

for (int 變數名甲 = 0; 變數名甲 integers.length; 變數名甲++) {

System.out.println(integers[變數名甲]); /* 依次輸出「1」、「2」、「3」、「4」 */

}

這裡的「變數名甲」是一個由編譯器自動生成的不會造成混亂的名字。

而遍歷一個Collection的操作也就可以採用這樣的寫法:

清單5:遍歷Collection的簡單方式

/* 建立一個Collection */

String[] strings = {“A”, “B”, “C”, “D”};

Collection list = java.util.Arrays.asList(strings);

/* 開始遍歷 */

for (Object str : list) {

System.out.println(str); /* 依次輸出「A」、「B」、「C」、「D」 */

}

這裡所用的for循環,則會在編譯期間被看成是這樣的形式:

清單6:遍歷Collection的簡單方式的等價代碼

/* 建立一個Collection */

String[] strings = {“A”, “B”, “C”, “D”};

Collection stringList = java.util.Arrays.asList(strings);

/* 開始遍歷 */

for (Iterator 變數名乙 = list.iterator(); 變數名乙.hasNext();) {

Object str = 變數名乙.next();

System.out.println(str); /* 依次輸出「A」、「B」、「C」、「D」 */

}

這裡的「變數名乙」也是一個由編譯器自動生成的不會造成混亂的名字。

因為在編譯期間,J2SE 1.5的編譯器會把這種形式的for循環,看成是對應的傳統形式,所以不必擔心出現性能方面的問題。

不用「foreach」和「in」的原因

Java採用「for」(而不是意義更明確的「foreach」)來引導這種一般被叫做「for-each循環」的循環,並使用「:」(而不是意義 更明確的「in」)來分割循環變數名稱和要被遍歷的對象。這樣作的主要原因,是為了避免因為引入新的關鍵字,造成兼容性方面的問題――在Java語言中, 不允許把關鍵字當作變數名來使用,雖然使用「foreach」這名字的情況並不是非常多,但是「in」卻是一個經常用來表示輸入流的名字(例如 java.lang.System類里,就有一個名字叫做「in」的static屬性,表示「標準輸入流」)。

的確可以通過巧妙的設計語法,讓關鍵字只在特定的上下文中有特殊的含義,來允許它們也作為普通的標識符來使用。不過這種會使語法變複雜的策略,並沒有得到廣泛的採用。

「for-each循環」的悠久歷史

「for-each循環」並不是一個最近才出現的控制結構。在1979正式發布的Bourne shell(第一個成熟的UNIX命令解釋器)里就已經包含了這種控制結構(循環用「for」和「in」來引導,循環體則用「do」和「done」來標識)。

2、防止在循環體里修改循環變數

在默認情況下,編譯器是允許在第二種for循環的循環體里,對循環變數重新賦值的。不過,因為這種做法對循環體外面的情況絲毫沒有影響,又容易造成理解代碼時的困難,所以一般並不推薦使用。

Java提供了一種機制,可以在編譯期間就把這樣的操作封殺。具體的方法,是在循環變數類型前面加上一個「final」修飾符。這樣一來,在循環體 里對循環變數進行賦值,就會導致一個編譯錯誤。藉助這一機制,就可以有效的杜絕有意或無意的進行「在循環體里修改循環變數」的操作了。

清單7:禁止重新賦值

int[] integers = {1, 2, 3, 4};

for (final int i : integers) {

i = i / 2; /* 編譯時出錯 */

}

注意,這只是禁止了對循環變數進行重新賦值。給循環變數的屬性賦值,或者調用能讓循環變數的內容變化的方法,是不被禁止的。

清單8:允許修改狀態

Random[] randoms = new Random[]{new Random(1), new Random(2), new Random(3)};

for (final Random r : randoms) {

r.setSeed(4); /* 將所有Random對象設成使用相同的種子 */

System.out.println(r.nextLong()); /* 種子相同,第一個結果也相同 */

}

3. 類型相容問題

為了保證循環變數能在每次循環開始的時候,都被安全的賦值,J2SE 1.5對循環變數的類型有一定的限制。這些限制之下,循環變數的類型可以有這樣一些選擇:

循環變數的類型可以和要被遍歷的對象中的元素的類型相同。例如,用int型的循環變數來遍歷一個int[]型的數組,用Object型的循環變數來遍歷一個Collection等。

清單9:使用和要被遍歷的數組中的元素相同類型的循環變數

int[] integers = {1, 2, 3, 4};

for (int i : integers) {

System.out.println(i); /* 依次輸出「1」、「2」、「3」、「4」 */

}

清單10:使用和要被遍歷的Collection中的元素相同類型的循環變數

Collection String strings = new ArrayList String();

strings.add(“A”);

strings.add(“B”);

strings.add(“C”);

strings.add(“D”);

for (String str : integers) {

System.out.println(str); /* 依次輸出「A」、「B」、「C」、「D」 */

}

循環變數的類型可以是要被遍歷的對象中的元素的上級類型。例如,用int型的循環變數來遍歷一個byte[]型的數組,用Object型的循環變數來遍歷一個Collection String(全部元素都是String的Collection)等。

清單11:使用要被遍歷的對象中的元素的上級類型的循環變數

String[] strings = {“A”, “B”, “C”, “D”};

Collection String list = java.util.Arrays.asList(strings);

for (Object str : list) {

System.out.println(str);/* 依次輸出「A」、「B」、「C」、「D」 */

}

循環變數的類型可以和要被遍歷的對象中的元素的類型之間存在能自動轉換的關係。J2SE 1.5中包含了「Autoboxing/Auto-Unboxing」的機制,允許編譯器在必要的時候,自動在基本類型和它們的包裹類(Wrapper Classes)之間進行轉換。因此,用Integer型的循環變數來遍歷一個int[]型的數組,或者用byte型的循環變數來遍歷一個 Collection Byte,也是可行的。

清單12:使用能和要被遍歷的對象中的元素的類型自動轉換的類型的循環變數

int[] integers = {1, 2, 3, 4};

for (Integer i : integers) {

System.out.println(i); /* 依次輸出「1」、「2」、「3」、「4」 */

}

注意,這裡說的「元素的類型」,是由要被遍歷的對象的決定的――如果它是一個Object[]型的數組,那麼元素的類型就是Object,即使裡面裝的都是String對象也是如此。

可以限定元素類型的Collection

截至到J2SE 1.4為止,始終無法在Java程序里限定Collection中所能保存的對象的類型――它們全部被看成是最一般的Object對象。一直到J2SE 1.5中,引入了「泛型(Generics)」機制之後,這個問題才得到了解決。現在可以用Collection T來表示全部元素類型都是T的Collection。

java中for循環的幾種寫法

以下為for循環的幾種寫法:

/***

方法一:最普通的不加思考的寫法

* p*優點:較常見,易於理解

* p* 缺點:每次都要計算list.size()*/

for (int i = 0; i list.size(); i++) {

System.out.println(list.get(i));

}

/***

方法二:數組長度提取出來

* p* 優點:不必每次都計算

* p* 缺點:

1、m的作用域不夠小,違反了最小作用域原則

2、不能在for循環中操作list的大小,比如除去或新加一個元素*/

int m = list.size();

for (int i = 0; i m; i++) {

System.out.println(list.get(i));

}

/***

方法三:數組長度提取出來

* p* 優點:

1、不必每次都計算

2、所有變數的作用域都遵循了最小範圍原則

* p* 缺點:

1、m的作用域不夠小,違反了最小作用域原則

2、不能在for循環中操作list的大小,比如除去或新加一個元素*/

for (int i = 0, n = list.size(); i n; i++) {

System.out.println(list.get(i));

}

/***

方法四:採用倒序的寫法

* p* 優點:

1、不必每次都計算

2、所有變數的作用域都遵循了最小範圍原則

* p* 缺點:

1、結果的順序會反

2、看起來不習慣,不易讀懂

* p* 適用場合:與顯示結果順序無關的地方:比如保存之前數據的校驗*/

for (int i = list.size() – 1; i = 0; i–) {

System.out.println(list.get(i));

}

/***

方法五:Iterator遍歷

* p* 優點:簡潔

* p* 缺點:*/

for (IteratorString it = list.iterator(); it.hasNext();) {

System.out.println(it.next());

}

/*** 方法六:

jdk1.5新寫法

* p* 優點:簡潔結合泛型使用更簡潔*

p* 缺點:jdk1.4向下不兼容*/

for (Object o : list) {

System.out.println(o);

}

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/230610.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-12-10 18:17
下一篇 2024-12-10 18:17

相關推薦

  • Java JsonPath 效率優化指南

    本篇文章將深入探討Java JsonPath的效率問題,並提供一些優化方案。 一、JsonPath 簡介 JsonPath是一個可用於從JSON數據中獲取信息的庫。它提供了一種DS…

    編程 2025-04-29
  • java client.getacsresponse 編譯報錯解決方法

    java client.getacsresponse 編譯報錯是Java編程過程中常見的錯誤,常見的原因是代碼的語法錯誤、類庫依賴問題和編譯環境的配置問題。下面將從多個方面進行分析…

    編程 2025-04-29
  • Java騰訊雲音視頻對接

    本文旨在從多個方面詳細闡述Java騰訊雲音視頻對接,提供完整的代碼示例。 一、騰訊雲音視頻介紹 騰訊雲音視頻服務(Cloud Tencent Real-Time Communica…

    編程 2025-04-29
  • Java Bean載入過程

    Java Bean載入過程涉及到類載入器、反射機制和Java虛擬機的執行過程。在本文中,將從這三個方面詳細闡述Java Bean載入的過程。 一、類載入器 類載入器是Java虛擬機…

    編程 2025-04-29
  • Python for循環求1到100的積

    Python中的for循環可以方便地遍歷列表、元組、字典等數據類型。本文將以Python for循環求1到100的積為中心,從多個方面進行詳細闡述。 一、for循環語法 Pytho…

    編程 2025-04-29
  • Java Milvus SearchParam withoutFields用法介紹

    本文將詳細介紹Java Milvus SearchParam withoutFields的相關知識和用法。 一、什麼是Java Milvus SearchParam without…

    編程 2025-04-29
  • Java 8中某一周的周一

    Java 8是Java語言中的一個版本,於2014年3月18日發布。本文將從多個方面對Java 8中某一周的周一進行詳細的闡述。 一、數組處理 Java 8新特性之一是Stream…

    編程 2025-04-29
  • Java判斷字元串是否存在多個

    本文將從以下幾個方面詳細闡述如何使用Java判斷一個字元串中是否存在多個指定字元: 一、字元串遍歷 字元串是Java編程中非常重要的一種數據類型。要判斷字元串中是否存在多個指定字元…

    編程 2025-04-29
  • VSCode為什麼無法運行Java

    解答:VSCode無法運行Java是因為默認情況下,VSCode並沒有集成Java運行環境,需要手動添加Java運行環境或安裝相關插件才能實現Java代碼的編寫、調試和運行。 一、…

    編程 2025-04-29
  • Java任務下發回滾系統的設計與實現

    本文將介紹一個Java任務下發回滾系統的設計與實現。該系統可以用於執行複雜的任務,包括可回滾的任務,及時恢復任務失敗前的狀態。系統使用Java語言進行開發,可以支持多種類型的任務。…

    編程 2025-04-29

發表回復

登錄後才能評論