[精讚] [會員登入]
1031

[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

你可能感興趣的文章

[PHP] 移除陣列或字串中的重覆元素 移除陣列或字串中的重覆元素

[PHP] 陣列新增資料及整理 在php陣列加入項目和重新整理陣列的方法

設定Google analytics API #1 -- Google網站上的設定 讓你的網站能夠存取你的Google analytics上面的資料

[PHP] CodeIgniter 3+pure+smarty安裝及環境設置1/2 PHP framework CodeIgniter 3+ pure CSS +smarty Template Engine的整合

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

[PHP+ci4] codeignitor4 Cache 及 Session 使用 memcached php 的framework codeignitor4 中的cache和session使用memcached

隨機好文

談借錢 人借錢時手心向上頭向下,人還錢時手心向下頭向上

[bc] linux 的計算機 bc 設定小數位數、計算π、次方根 linux 的計算機 bc 設定小數位數、計算π、次方根

[PHP] 檢查檔案是否是圖檔 使用getimagesize函數檢查檔案是否是圖檔

[Wildfly10] 發佈war檔 deploy war file onto wildfly10

[MYSQL] 設定字串欄位的預設值 新增表格的時候,字串欄位給予預設空值;數字欄位給預設數值;日期欄位給空值。