Heim > Backend-Entwicklung > PHP-Tutorial > switch语句中省略break后为什么会执行不满足的case条件后的语句?执行的依据不是比对case条件吗?

switch语句中省略break后为什么会执行不满足的case条件后的语句?执行的依据不是比对case条件吗?

WBOY
Freigeben: 2016-06-06 20:48:28
Original
1764 Leute haben es durchsucht

<code class="lang-php">$a=5;
switch($a){
  case 6:
    echo "\$a is 6<br>";
  case 5:
    echo "\$a is 5<br>";
  case 4:
    echo "\$a is 4<br>";
}
</code>
Nach dem Login kopieren
Nach dem Login kopieren

如上例中,我的理解是每次$a跟case后的值比对,符合的话就输出语句,不符合则比对下一个case条件。但是浏览器的输出是
$a is 5
$a is 4
我不太明白最后一个case语句中明明$a!=4还会输出。
(我之前对switch语句必须加上break的理解是:这样可以在找到符合条件的case后立即跳出switch从而加快执行速度。现在看来不是的。)

回复内容:

<code class="lang-php">$a=5;
switch($a){
  case 6:
    echo "\$a is 6<br>";
  case 5:
    echo "\$a is 5<br>";
  case 4:
    echo "\$a is 4<br>";
}
</code>
Nach dem Login kopieren
Nach dem Login kopieren

如上例中,我的理解是每次$a跟case后的值比对,符合的话就输出语句,不符合则比对下一个case条件。但是浏览器的输出是
$a is 5
$a is 4
我不太明白最后一个case语句中明明$a!=4还会输出。
(我之前对switch语句必须加上break的理解是:这样可以在找到符合条件的case后立即跳出switch从而加快执行速度。现在看来不是的。)

你可以这样理解,switch会根据条件,跳转到第一个匹配的 case 处继续执行。
case 只是一个供switch 跳转的标记,并没有划分区块的作用。

所以:

  • 即使有多个case与switch匹配,也只会跳转到第一个匹配的case.
  • 如果不break, 会从匹配的第一个case开始,一直执行到整个switch结构结束.

swich 只是跳转到那里开始执行,如果不break 会把下面的所有case全执行一遍的。

这是基础!问答你这个问题 我感觉一点成就感都没。。。。

原理很简单: 当某case后的值与$a匹配时,该case的代码块将被执行。 break之所以存在,就是放置所匹配case之后的代码会执行下去。如果$a=6; 那么6、5、4都会被输出

因为switch并不是一种模式匹配,它类似于汇编中的jmp。

这种语法的原始目的要满足语义的连贯性,请看下面的场景,

<code>switch($a){
  case 6:
  case 5:
    echo "\$a is not 4<br>";
    break;
  case 4:
    echo "\$a is 4<br>";
}
</code>
Nach dem Login kopieren

6和5的处理方式一样。

Verwandte Etiketten:
php
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage