Fos*_*tah 74 java language-design switch-statement long-integer
以下是Sun Java教程的摘录:
一种开关用的工作原理
byte
,short
,char
,和int
原始数据类型.它还与枚举类型(在类和继承讨论)和少数特殊类作品是"包装"某些基本类型:Character
,Byte
,Short
,和Integer
(在简单的数据对象讨论).
必须有一个很好的理由为什么long
不允许原始数据类型.有人知道这是什么吗?
Nei*_*fey 47
我认为在某种程度上,这可能是基于典型切换使用的任意决定.
交换机基本上可以通过两种方式实现(或者原则上是组合):对于少数情况,或者其值大范围分散的情况,交换机基本上等同于临时变量上的一系列ifs(打开的值必须只评估一次).对于或多或少连续值的中等数量的情况,使用切换表(Java中的TABLESWITCH指令),从而有效地在表中查找要跳转到的位置.
这些方法中的任何一个原则上都可以使用长值而不是整数.但是我认为将指令集和编译器的复杂性与实际需求进行平衡可能只是一个实际的决定:你需要切换很长时间的情况很少见,因此必须重新编写为一系列的IF语句,或以其他方式工作(如果有问题的长值靠得很近,你可以在你的Java代码中切换int减去最低值的结果).
Don*_*ows 19
因为他们没有在字节码中实现必要的指令,你真的不想写那么多的情况,无论你的代码如何"生产就绪"......
[编辑:摘自对此答案的评论,并在背景上添加一些内容]
确切地说,2,32是很多情况下,任何方法都有足够长的时间来容纳更多的东西,这将是非常可怕的!用任何语言.(我知道的任何语言的任何代码最长的功能是在6K小SLOC -是的,这是一个很大的switch
-它真的无法控制的)如果你真的坚持与具有正long
,你应该只有一个int
或更少,那么你有两个真正的选择.
在哈希函数的主题上使用一些变体来压缩long
成一个int
.最简单的一个,只有当你输入错误时才使用,就是施展!更有用的是这样做:
(int) ((x&0xFFFFFFFF) ^ ((x >>> 32) & 0xFFFFFFFF))
Run Code Online (Sandbox Code Playgroud)
在打开结果之前.你必须弄清楚如何改变你正在测试的案例.但实际上,这仍然很可怕,因为它没有解决许多案件的真正问题.
如果您正在处理大量案例,那么更好的解决方案是将您的设计更改为使用Map<Long,Runnable>
类似的东西,以便您查找如何分配特定值.这允许您将案例分成多个文件,这在案例数量变大时更容易管理,尽管组织所涉及的实现类主机的注册变得更加复杂(注释可能有助于您自动构建注册码).
FWIW,我做了这许多年以前(我们通过项目切换到新推出的J2SE 1.2的一部分的方式)建立一个自定义的字节码引擎时,用于模拟大规模并行硬件(无,重复使用JVM不会有合适的,由于根本所涉及的不同的值和执行模型)并且它极大地简化了相对于代码switch
的C版本所使用的大的代码.
要重申带回家的消息,想要switch
在a long
上表明你的程序中的类型错误,或者你正在构建一个涉及很多变化的系统,你应该使用类.在任何一种情况下重新考虑的时间.
因为查找表索引必须是32位的。