[精讚] [會員登入]
1040

[PHP>7.3] switch中的 Did you mean to use "continue 2"? 除錯

這近更新 PHP到7.3版以後,出現這樣的錯:targeting switch is equivalent to "break". Did you mean to use "continue 2"?解決方法

分享此文連結 //n.sfs.tw/15080

分享連結 [PHP>7.3] switch中的 Did you mean to use "continue 2"? 除錯@新精讚
(文章歡迎轉載,務必尊重版權註明連結來源)
2021-12-24 11:07:38 最後編修
2021-05-05 13:18:13 By 張○○
 

自動目錄

這近更新 PHP到7.3版以後,出現這樣的錯:

Warning: "continue" targeting switch is equivalent to "break". Did you mean to use "continue 2"? in /path/to/x.php on line 123

程式碼類似:

while ($foo) {
   switch ($bar) {
      case "baz":
         continue;
         // Warning: "continue" targeting switch is equivalent to
         //          "break". Did you mean to use "continue 2"?
   }
   do();
}

原本的邏輯是當 $bar== 'baz' 的情況時,就跳過switch後面的部分,也就是第8行的do()不會被執行到,重跑while的判斷。

到了php 7.3版以後,就出錯了,出錯原因在於7.3版以後,認真的把switch視為迴圈看待,事實上switch本來就屬於迴圈,而不是一個函數

這也能說明為什麼case裡面會有"break"的存在。

如果迴圈裡有一個continue的話,代表就是重跑下一筆判斷,但是在switch裡重跑判斷就會無窮迴圈,所以在switch裡continue=break;

continue 2?

因此改寫成continue 2,這裡的2代表父迴圈:繼續父迴圈,自己是1省略不寫,父迴圈是2,祖父迴圈是3、曾祖父迴圈是4以此類推…

以下範例

for($ii=0;$ii<5;$ii++){
  for($jj=0;$jj<10;$jj++){
    switch($jj){
      case 1: print "ii: $ii, jj: $jj\n"; continue 3;
    }
  }
}

第4行採用 continue 3,所以會直接跳到 第1行的祖父迴圈

執行結果:

ii: 0, jj: 1
ii: 1, jj: 1
ii: 2, jj: 1
ii: 3, jj: 1
ii: 4, jj: 1

參考資料

[1] https://www.php.net/manual/en/migration73.incompatible.php

[2] https://www.php.net/manual/en/control-structures.continue.php

 

 

 

END

你可能感興趣的文章

[Smarty5] 如何在樣版中使用php本身的函式 解決 smarty5版後不能直接叫用 php函式的問題

設定Google analytics API #3 -- 查詢範例 讓你的網站能夠存取你的Google analytics上面的資料

[PHP] 字串編碼及解碼函式 為何要將字串編碼?理由很簡單,就是不要讓人家輕易的知道字串內容是什麼。例如點選分頁時,我們常會用這樣的連結: index

PHP程式經驗 #2 -- print和echo的差異 常在寫php的人一定會想知道echo和print這兩個函數有什麼不一樣 驗證 1. 比較print 和echo 函式的執

PHP cli 傳入參數 php cli (PHP命令列的傳入參數使用方法

[PHP] 如何寫callback function 召回函數(回呼函數) PHP如何寫召回函數或回呼函數(callback function)?

隨機好文

問問題 問問題其實內涵很深,我悟了很久才懂。 有人問題的目的並不一定是想要得到答案,有時只是純粹想問問題..

[MAC] 安裝APACHE+PHP OS Darwin OpenIDMac1deAir 15.6.0 Darwin Kernel Version 15.6.

關閉瀏覽器表單的自動完成autocomplete 什麼是自動完成?就是當我們在網頁的輸入文字欄位中打入文字時,瀏覽器會把曾輸入過歷史記錄中找出來讓我們選擇。

兩次使用InnoDB的慘痛經驗 Mysql 的Innodb引擎雖然好用,但是我得說說我兩次的慘痛經驗,這讓我考慮以後可能不會再使用innodb了

[Mysql/MariaDB] 查看資料庫所占空間 查看資料庫在磁碟中所占空間