PHP中的switch語句的用法實(shí)例詳解
switch是一個(gè)開關(guān)語句,那么很多朋友都只知道簡單的switch開關(guān)語句的用法了,下面一聚教程小編就為各位詳細(xì)的介紹一下switch用法例子吧。
只所以稱為“高級(jí)”用法,是因?yàn)槲疫Bswitch的最基礎(chǔ)的用法都還沒有掌握,so,接下來講的其實(shí)還是它的基礎(chǔ)用法!
switch 語句和具有同樣表達(dá)式的一系列的 IF 語句相似。很多場合下需要把同一個(gè)變量(或表達(dá)式)與很多不同的值比較,并根據(jù)它等于哪個(gè)值來執(zhí)行不同的代碼。這正是 switch 語句的用途。
注意: 注意和其它語言不同,continue 語句作用到 switch 上的作用類似于 break。如果在循環(huán)中有一個(gè) switch 并希望 continue 到外層循環(huán)中的下一個(gè)輪回,用 continue 2。
下面兩個(gè)例子使用兩種不同方法實(shí)現(xiàn)同樣的事,一個(gè)用一系列的 if 語句,另一個(gè)用 switch 語句:
Example #1 switch 結(jié)構(gòu)
<?php if ($i == 0) { echo "i equals 0"; } elseif ($i == 1) { echo "i equals 1"; } elseif ($i == 2) { echo "i equals 2"; } switch ($i) { case 0: echo "i equals 0"; break; case 1: echo "i equals 1"; break; case 2: echo "i equals 2"; break; } ?>
Example #2 switch 結(jié)構(gòu)可以用字符串
<?php switch ($i) { case "apple": echo "i is apple"; break; case "bar": echo "i is bar"; break; case "cake": echo "i is cake"; break; } ?>
重點(diǎn):(這就是我先前一直沒掌握的地方!)
為避免錯(cuò)誤,理解 switch 是怎樣執(zhí)行的非常重要。switch 語句一行接一行地執(zhí)行(實(shí)際上是語句接語句)。開始時(shí)沒有代碼被執(zhí)行。僅當(dāng)一個(gè) case 語句中的值和 switch 表達(dá)式的值匹配時(shí) PHP 才開始執(zhí)行語句,直到 switch 的程序段結(jié)束(如 return 語句)或者遇到第一個(gè) break 語句為止。如果不在 case 的語句段最后寫上 break 的話,PHP 將繼續(xù)執(zhí)行下一個(gè) case 中的語句段。例如:
<?php switch ($i) { case 0: echo "i equals 0"; case 1: echo "i equals 1"; case 2: echo "i equals 2"; } ?>
特別說明:這里如果 $i 等于 3,PHP不會(huì)執(zhí)行任何echo語句!但是,如果 $i 等于 0,PHP 將執(zhí)行所有的 echo 語句!如果 $i 等于 1,PHP 將執(zhí)行后面兩條 echo 語句。只有當(dāng) $i 等于 2 時(shí),才會(huì)得到“預(yù)期”的結(jié)果——只顯示“i equals 2”。所以,別忘了 break 語句就很重要(即使在某些情況下故意想避免提供它們時(shí))。
[效率]在 switch 語句中條件只求值一次并用來和每個(gè) case 語句比較。在 elseif 語句中條件會(huì)再次求值。如果條件比一個(gè)簡單的比較要復(fù)雜得多或者在一個(gè)很多次的循環(huán)中,那么用 switch 語句可能會(huì)快一些。
在一個(gè) case 中的語句也可以為空,這樣只不過將控制轉(zhuǎn)移到了下一個(gè) case 中的語句。
<?php switch ($i) { case 0: case 1: case 2: echo "i is less than 3 but not negative"; break; case 3: echo "i is 3"; } ?>
一個(gè) case 的特例是 default。它匹配了任何和其它 case 都不匹配的情況。例如:
<?php switch ($i) { case 0: echo "i equals 0"; break; case 1: echo "i equals 1"; break; case 2: echo "i equals 2"; break; default: echo "i is not equal to 0, 1 or 2"; } ?>
case 表達(dá)式可以是任何求值為簡單類型的表達(dá)式,即整型或浮點(diǎn)數(shù)以及字符串。不能用數(shù)組或?qū)ο?,除非它們被解除引用成為簡單類型?nbsp;
【實(shí)戰(zhàn)】 根據(jù)上面的知識(shí)點(diǎn),編寫這么一個(gè)函數(shù):計(jì)算容量值實(shí)際代表的字節(jié)數(shù)
<?php /** * 返回字節(jié)數(shù) * * @param string $val 如 400M */ function return_bytes($val = '') { $val = trim($val); $last = strtolower($val{strlen($val)-1}); switch ($last) { case 'g': $val *= 1024; case 'm': $val *= 1024; case 'k': $val *= 1024; } return $val; } $memorylimit = ini_get('memory_limit'); echo $memorylimit, '<br/>'; echo return_bytes($memorylimit); 輸出: 400M 419430400
特別說明:$val = 400M時(shí),case 'm' 被命中,其下的 $val *= 1024; 被執(zhí)行,但因?yàn)闆]有 break 語言,所以會(huì)繼續(xù)命中 case 'k',并執(zhí)行其下的 $val *= 1024;語句,so,總體上相當(dāng)于執(zhí)行了 400 * 1024 * 1024 。
以上就是本文的全部敘述,希望對(duì)大家學(xué)習(xí)switch用法有所幫助。
相關(guān)文章
又一個(gè)PHP實(shí)現(xiàn)的冒泡排序算法分享
這篇文章主要介紹了又一個(gè)PHP實(shí)現(xiàn)的冒泡排序算法分享,標(biāo)題中的又一個(gè)是指本站已經(jīng)有好幾篇冒泡排序算法的文章了,如果這個(gè)沒有滿足你的要求,請看相關(guān)文章里的其他實(shí)現(xiàn)方法吧,需要的朋友可以參考下2014-08-08

PHP Callable強(qiáng)制指定回調(diào)類型的方法

Yii輸入正確驗(yàn)證碼卻驗(yàn)證失敗的解決方法

zen_cart實(shí)現(xiàn)支付前生成訂單的方法