迴圈是流程式控制制的又一重要結構,“白天-黑夜-白天-黑夜”屬於時間上的迴圈,古人“年復一年、日復一日”的“日出而作、日落而息”便是每天周而複始的生活。電腦程式處理迴圈結構時,給定一段每次都要執行的代碼塊,然後分別指定迴圈的開始條件和結束條件,就形成了常見的迴圈語句。最簡單的迴圈結構只需一個while ...
迴圈是流程式控制制的又一重要結構,“白天-黑夜-白天-黑夜”屬於時間上的迴圈,古人“年復一年、日復一日”的“日出而作、日落而息”便是每天周而複始的生活。電腦程式處理迴圈結構時,給定一段每次都要執行的代碼塊,然後分別指定迴圈的開始條件和結束條件,就形成了常見的迴圈語句。最簡單的迴圈結構只需一個while關鍵字設置迴圈條件即可,下麵是根據輸入數字決定迴圈次數的代碼例子:
System.out.println("長夜漫漫,無心睡眠"); System.out.println("請給他設定一個睡醒的年限"); Scanner scan = new Scanner(System.in); // 從控制台接收輸入文本 /* nextLine方法表示接收一行文字,以回車鍵結尾 */ int limit = scan.nextInt(); int year = 0; while (year < limit) { // 當條件滿足時,在迴圈內部持續處理 System.out.println("已經過去的年份:"+year); year++; } System.out.println("他足足睡了這麼多年:"+year);
運行上面的測試代碼,輸入數字3,連同處理結果的完整日誌如下圖所示。
單純的while語句是在每次迴圈開始前進行條件判斷,符合條件則執行一圈代碼,不符合的話就退出迴圈。Java還提供了另一種形式的do-while迴圈,該迴圈以do關鍵字開頭,以while語句結尾,並且條件判斷也挪到了每次迴圈結束後再處理了。條件判斷的位置變更造成了while迴圈和do-while迴圈之間的差異,while迴圈在開始工作前必定先判斷迴圈條件是否成立,一旦條件不成立,那麼當前迴圈一次都不會執行,直接跳到迴圈後面的語句了。而do-while迴圈遲至第一次迴圈執行完畢才做條件判斷,只有發現迴圈條件不成立時才姍姍來遲退出迴圈。這意味著,即使迴圈條件一開始就不滿足,do-while迴圈也一定要進入迴圈內部,到此一游後才拍拍屁股離開。
下麵通過一個實驗觀察while迴圈和do-while迴圈的不同之處,演示代碼見下,主要是把迴圈外圍的while改成了do-while:
int year = 0; do { System.out.println("已經過去的年份:"+year); year++; } while (year < limit); // 當條件滿足時,在迴圈內部持續處理 System.out.println("他足足睡了這麼多年:"+year);
然後運行演示代碼,倘若輸入正數,則while迴圈和do-while迴圈列印的日誌信息並無區別;要是輸入負數,此時二者列印的日誌就分道揚鑣了。while迴圈的日誌列印結果如下麵的左圖所示,do-while迴圈的日誌列印結果如下麵的右圖所示。
從上面的實驗結果看出,在條件不滿足的情況之下,do-while迴圈依舊強行遛達了一圈,這種先斬後奏的特性過於武斷,故而限制了它的使用範圍。
不管是while迴圈還是do-while迴圈,它們的條件判斷都獨立於迴圈內部代碼,要麼在迴圈開始前判斷,要麼在迴圈結束後判斷。如果要求在內部代碼的中間就插入條件判斷,並據此決定是退出迴圈還是繼續迴圈,那又該當若何?為此Java給迴圈語句引入了break和continue兩個關鍵字,其中break的作用是跳出整個迴圈,而continue的作用是跳過本次迴圈的剩餘代碼、直接繼續下次的迴圈判斷和處理。
現在準備修改之前的代碼,打算在println和year++中間進行是否繼續迴圈的判斷。首先要把while語句後面的條件式子改為true,表示每次迴圈前後取消預設的條件校驗。然後在println和year++之間插入if語句開展條件判斷,條件滿足的話,就執行year++以及continue操作;條件不滿足的話,就直接跳出整個迴圈,繼續迴圈以外的代碼處理。根據上述思路修改迴圈代碼,改好的代碼如下所示:
int year = 0; while (true) { // 當條件滿足時,在迴圈內部持續處理 System.out.println("已經過去的年份:"+year); if (year < limit) { // 這裡判斷能否跳出迴圈 year++; continue; // 繼續下一次迴圈 } else { break; // 跳出迴圈。即跳到while迴圈的右花括弧之後 } } System.out.println("他足足睡了這麼多年:"+year);
接著運行修改之後的代碼,列印出來的迴圈運行日誌如下圖所示:
可見此時迴圈內部接連列印了年份1、年份2、年份3,共三行日誌。對比修改之前只列印年份1、年份2的兩行日誌,顯然修改之後的代碼邏輯更靈活,因為無論迴圈的內部代碼如何千變萬化,程式員總能找到合適的地方退出迴圈處理。