本文目錄一覽:
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);
}
java中for嵌套for循環的詳細講解?
就是 一個執行循序問題,先執行外面的循環:
1 for(int i=0;i10;i++){
2 for(int j=0;j3;j++) {
3 System.out.print(“i*j=”+i*j);
4 }
5 }
6 ….
….
當開始循環的時候,i=0,然後繼續運行,j=0,輸出i*j=0
此時循環從j=1,i仍舊為0 , j的值為2
輸出結果為i*j=0,此時j++,j的值為2
循環從j=2,i仍舊為0 ,輸出結果為i*j=0
當j=3,不滿足j3跳出內部for循環,執行外部for循環第二行代碼,此時i++,i的值變為1
循環i=1, j=0時,結果為i*j=0
i=1,j=1 結果為i*j=1;
;;;;;;
;;;;;
當i循環到9,j=2是,輸出循環結果為i*j=18
當i=10,不滿足i10,跳出外部循環,執行第6行
我只是拿一個例子給你講解的,我像這樣比給你講解概念好理解。
一,在for循環中,循環控制變數的初始化和修改都放在語句頭部分,形式較簡潔,且特別適用於循環次數已知的情況。在while循環中,循環控制變數的初始化一般放在while語句之前,循環控制變數的修改一般放在循環體中,形式上不如for語句簡潔,但它比較適用於循環次數不易預知的情況(用某一條件控制循環)。
二,foreach不是一個關鍵詞,它指的是一種java里的循環方式,顧名思義代表對於每一個,表示每次給你要遍歷的東西生成一個降維對象,然後訪問。
比如說for(a:b),b是你要遍歷的東西,每次循壞都會生成一個b的子集a,a是你自己命名的一個元素,在這個for里我們訪問的就是這個a,每次循環都會訪問一個新的a。
三,看你圖裡的代碼,balances是二維數組,假設看成一個矩陣,我們需要一行一行遍歷它,那麼double[] row就是這個矩陣每行的意思。回到代碼,for(double[] row:balances)就是指對於balances的每行row,同樣的道理for(double b:row)的意思是對於每行row里的每個元素b,因為row是一維的數組,對它降維就是單個元素了。其中的row和b都是由你自己命名的,愛起什麼名就起什麼名,起完了名就可以在循環體里直接用了。遍歷順序就是順序遍歷,從前到後,跟你用i++,j++一樣。
這種寫法的好處在於,一是不需要管遍歷的次數,二是你定義的子元素可以直接用,看起來比a[i]、a[j]方便。
java怎麼看for最後循環多少次
java循環次數_java學習日記,循環次數的確定
一個循環的次數的確定,一定是循環變數變化的過程來確定的。
在一個for循環里,控制循環次數的方法有如下幾種:
1.這種方法是通過控制循環執行條件和起始值來控制循環次數。這是最基礎的方法,也是最簡單,最常用的方法。
例如:
for(i=0;i100;i++){
System.out.print(i);
}
這段代碼的循環次數是100次,因為循環起始值是0,循環執行條件是循環變數小於100,循環變數每次變化過程是自增1,
所以循環次數是100次。
2.這種方法是通過控制循環變數變化的過程來控制循環次數
for(i=0;i200;i+=2){
System.out.print(i);
}
這段代碼的循環次數也是100次,但是循環變數的執行條件是循環變數小於200,循環變數每次自增2,每當增加2,循環進行一次,
那麼循環次數就等於200/2=100次
3.這種方法是通過循環體內控制循環的次數
for(i=0;i200;i++)1{
System.out.print(i);
if(i==99){
break;
}
}
這段代碼循環次數理應是200次,但實際執行了100次,是通過循環體內某個條件控制循環結束的時機,當i=99的時候,循環結束。
4,這種方法是通過循環體內篩選循環變數的值來控制實際使用循環次數。
for(i=0;i200;i++){
if(i%2==0){
System.out.print(i);
}
}
這段代碼循環次數是200次,但是結果是100個,實際我們使用了100次循環,是通過在循環體內篩選循環變數的值控制使用循環次數。
java for循環的解釋
循環的意思就是讓程序重複地執行某些語句。在程序設計時,常常需要處理大量的重複動作,採用循環結構可以降低程序書寫的長度和複雜度,可使複雜問題簡單化,提高程序的可讀性和執行速度。其中,for循環就是循環結構的一種,另外還有while循環和do-while循環語句。但是for循環是開發者明確知道了循環次數。
For循環格式如下:
for(賦初值;判斷條件;賦值加減){
執行語句
}
若是在循環主體中要處理的語句只有一個,可以將大括弧省去。下面列出for循環的流程:
(1)第一次進入for循環是,要為循環控制變數賦初值。
(2)根據判斷條件內容檢查是否要繼續執行循環,當判斷條件為真(true)時,繼續執行循環主體內的語句;判斷條件為假(false)時,則會跳出循環,執行其它語句。
執行完循環主體內的語句後,循環控制變數會根據增減量的要求更改循環控制變數的值,然後再回到步驟(2)重新判斷是否繼續執行循環。更具上面可以畫出下面的流程圖。
下面是成功例子
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。
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/238870.html