浅谈java switch如果case后面没有break,会出现什么情况?
switch表达式的取值:byte,short,int,char
JDK5以后可以是枚举
JDK7以后可以是String
如下代码, case“A” :之后没有break,此刻会继续执行 case “B”:的代码 System.out.println("bbbbbbbb");遇到break之后,代码运行结束。
public static void main(String[] args) { String s = "A"; switch (s) { case "A": System.out.println("aaaaaaaa"); /* * 注意:此处如果没有添加break,则代码会继续执行,即使不满足case条件也会执行,直到遇到break */ //break; case "B": System.out.println("bbbbbbbb"); break; default: System.out.println("others"); break; } }
结果:
default写在最前面的情况:
public static void main(String[] args) { int x = 2; int y = 3; switch(x){ /* * default 写在最前面,但是如果没有写break;,还是会无条件执行后面的语句 */ default: y++; System.out.println("default"); //break; case 3: y++; System.out.println(y); case 4: y++; System.out.println(y); } System.out.println("y="+y); }
结果:
总结:
break;语句"不是必须的"。如果不写,如果一旦case相应的值成功,但内部没有break语句,那么将会无条件(不再进行case匹配)的继续向下执行其它case中的语句,直到遇到break;语句或者到达switch语句结束。
补充知识:Java小细节——switch有无break的区别
switch大家都很熟悉,可以从一系列代码中选出一段去执行,它的格式如下:
switch(c){ case 1:statement;break; case 2:statement;break; case 3:statement;break; case 4:statement;break; case 5:statement;break; default:statement; }
我们来看一下下面这段代码,然后判断下会输出什么。
public static void main(String[] args) { doSwitch(0); } static void doSwitch(int i) { switch (i) { case 0: { System.out.println(0); } case 1: { System.out.println(1); } case 2: { System.out.println(2); } case 3: { System.out.println(3); } default:{ System.out.println("default"); } } }
运行结果是:
0
1
2
3
default
=================让我们加上break试试================
虽然switch-case中的break是可选的,但是break会较大的影响到运行的效果,所以得牢记有无break的区别。
以上这篇浅谈java switch如果case后面没有break,会出现什么情况?就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
Java并发读写锁ReentrantReadWriteLock 使用场景
ReentrantReadWriteLock是Java中一种高效的读写锁,适用于读多写少的并发场景,它通过允许多个线程同时读取,但在写入时限制为单线程访问,从而提高了程序的并发性和性能,本文给大家介绍Java并发读写锁ReentrantReadWriteLock 使用场景,感兴趣的朋友跟随小编一起看看吧2024-10-10java出现no XXX in java.library.path的解决及eclipse配
这篇文章主要介绍了java出现no XXX in java.library.path的解决及eclipse配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教2023-12-12SpringCloud 客户端Ribbon负载均衡的实现方法
Ribbon 是 Netflix 提供的一个基于 Http 和 TCP 的客户端负载均衡工具,且已集成在 Eureka 依赖中,这篇文章主要介绍了SpringCloud 客户端Ribbon负载均衡的实现方法,需要的朋友可以参考下2022-06-06
最新评论