1.基本語法
while循環(huán)的基本語法如下所示:
while(循環(huán)條件){
//循環(huán)體
}
while循環(huán)屬于是一種”當型“的循環(huán)結構,當循環(huán)條件為true,循環(huán)體就會執(zhí)行,不滿足條件,循環(huán)體一次也不會執(zhí)行。所以在while循環(huán)中,當執(zhí)行到一定的程度后,循環(huán)條件要變成false,否則就會變成”死循環(huán)“。死循環(huán)會導致CPU被100%占用,用戶會感覺電腦運行緩慢,所以我們要避免編寫死循環(huán)代碼。另外如果循環(huán)條件的邏輯寫得有問題,也可能會造成意料之外的結果。
大家還要注意,在while循環(huán)中,也是可以進行嵌套其他循環(huán)的!
2. 執(zhí)行順序
根據while循環(huán)的基本語法,壹哥給大家梳理一下它的執(zhí)行順序:
1.如果while循環(huán)里的條件為true,則執(zhí)行循環(huán)體;
2.循環(huán)體執(zhí)行完畢后,會再次判斷循環(huán)條件......;
3.直到循環(huán)條件為false,就結束循環(huán)。
3.情況分析
問題1:
請問while循環(huán)可以被return結束嗎?
在Java中,可以使用return語句來結束一個方法的執(zhí)行,并返回一個值(如果需要的話)。然而,如果return語句出現在while循環(huán)中,會發(fā)生什么取決于return語句所在的上下文和語義。
如果return語句在while循環(huán)的內部并且不在任何條件語句的分支中,那么return語句將會結束方法的執(zhí)行并返回一個值。例如:
public int findFirstPositive(int[] nums) {
int i = 0;
while (i < nums.length) {
if (nums[i] > 0) {
return nums[i];
}
i++;
}
return -1; // 如果找不到正數,就返回-1
}
在這個例子中,while循環(huán)用于遍歷一個整數數組,查找第一個正數。如果找到了正數,return語句將會立即結束方法的執(zhí)行并返回該正數。
如果return語句出現在while循環(huán)的外部,那么return語句將會結束方法的執(zhí)行并返回一個值,而while循環(huán)會在此之前結束。例如:
public int findFirstPositive(int[] nums) {
int i = 0;
while (i < nums.length) {
if (nums[i] > 0) {
break;
}
i++;
}
return (i < nums.length) ? nums[i] : -1; // 如果找不到正數,就返回-1
}
在這個例子中,while循環(huán)用于遍歷一個整數數組,查找第一個正數。如果找到了正數,break語句將會立即結束while循環(huán),然后執(zhí)行return語句返回該正數。如果沒有找到正數,while循環(huán)會遍歷整個數組,然后執(zhí)行return語句返回-1。
總之,return語句可以結束while循環(huán)的執(zhí)行,但具體行為取決于return語句所在的上下文和語義。
問題2:
為什么JDK源碼中,無限循環(huán)大多使用for(;;)而不是while(true)?
在JDK源碼中,無限循環(huán)大多使用 for 而不是 while(true) 的原因是 for 循環(huán)語法更為簡潔、直觀,且具有更好的可讀性和可維護性。
使用 for 循環(huán)時,循環(huán)變量的初始化、循環(huán)條件的判斷以及每次循環(huán)后的迭代操作都可以在一個語句塊中完成。這樣可以使代碼更為緊湊,同時也更易于理解和修改。
相比之下,使用 while(true) 進行無限循環(huán)會顯得比較笨重,因為循環(huán)變量的初始化和迭代操作需要額外的語句來完成。此外,使用 while(true) 進行無限循環(huán)可能會導致代碼可讀性和可維護性下降,因為它不夠直觀,可能需要花費更多的時間來理解代碼的含義。
總之,在JDK源碼中,使用 for 循環(huán)進行無限循環(huán)是一種更好的選擇,因為它可以提高代碼的可讀性、可維護性和可靠性。