cdm*_*kay 81 java performance switch-statement
考虑以下两个带括号的片段:
switch (var) {
case FOO: {
x = x + 1;
break;
}
case BAR: {
y = y + 1;
break;
}
}
Run Code Online (Sandbox Code Playgroud)
没有括号:
switch (var) {
case FOO:
x = x + 1;
break;
case BAR:
y = y + 1;
break;
}
Run Code Online (Sandbox Code Playgroud)
我知道,在带括号的代码段中,通过将每个案例括在大括号中来创建一个新的范围.但是,如果每个案例都不需要新范围(即没有重用变量名称),那么在案例中使用大括号是否存在任何性能损失?
Tof*_*eer 20
从执行的角度来看,没有性能损失.
从编译的角度来看,轻微的性能损失,因为有更多要解析,但如果有人真正关心它,他们将不得不在一行编写他们的代码:-)
现在,对于我们帖子的意见部分...我总是加入{和}因为可维护性会受到惩罚,因为你可能不得不把它们放在以后的日期,这可能是一种痛苦在以后...但这是103%的个人喜好.
Rea*_*ed. 12
我们知道开关盒的支架不是必需的.使用大括号案例可能会导致对案例范围的混淆.
开括号通常与有意义的东西相关联,如函数的开始或循环的开始或类声明的开始或数组初始化的开始等...我们知道,当遇到中断时,一个案例突破了switch块声明.因此,使用花括号似乎意味着对于无知读者的案例的不同范围的想法.因此,为了更好地编程可读性,最好避免使用花括号.
即当我有类似的东西,
switch(i)
{
case 1 :
{
//do something
}
System.out.println("Hello from 1");
case 2:
....
}
Run Code Online (Sandbox Code Playgroud)
"Hello from 1"被打印出来.但是大括号的使用可能暗示一个无知的读者,案件以'}'结尾,已经知道在循环,方法等情况下花括号通常表示什么.
就像我们在'C'中有跳转到标签的语句一样,控制只是转移到大小写并继续它的执行.因此,有了这种理解,在为switch编写case时使用花括号只是一种不好的做法.
从技术上讲,当使用有效语法时,您可以使用额外的一对花括号来包围代码的任何块.在开关中使用大括号看起来至少对我来说很糟糕,因为它似乎给出了与我上面说过的不同的感觉.
我的建议:避免使用周围的支架来处理开关盒.
jkl*_*klp 10
有牙套.
切换语句有很多东西可以出错我尽量避免使用它们,即
使用大括号是防止在case语句之间有意和无意地共享变量的一种方法
这个问题可能会被关闭为"争论性"(BRACE WAR!),但是到底是什么.我实际上喜欢案件之后的大括号.对我而言,丑陋的切换语法看起来更像是其他语言结构.(在这种"案例"中使用大括号不会受到惩罚)
您说可以省略大括号,因为没有重用变量名称.通过重用变量名,我假设你的意思是声明一个相同类型的新变量.
大括号实际上是最有用的,以确保您不会case错误地在不同的s中重用相同的变量.它们今天没有声明任何变量,但有人会在明天添加它们而没有大括号,代码容易出错.