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