case low ... high :
case 范围的行为就好像为从 low 到 high(包含边界值)的给定范围内的每个值指定了 case 标签。(如果 low 和 high 相等,则 case 范围仅指定一个值。)下限值和上限值必须符合 C 标准的要求,即它们必须是有效的整型常量表达式(C 标准 6.8.4.2)。case 范围和 case 标签可以随意混合,一个 switch 语句中可以指定多个 case 范围。
以下编程示例说明了 switch 语句中的 case 范围:
enum kind char_class(char c) { enum kind result; switch(c) { case 'a' ... 'z': case 'A' ... 'Z': result = alpha; break; case '0' ... '9': result = number; break; case ' ': case '\n': case '\t': case '\r': case '\v': result = white; break; default: result = other; break; }
除了 case 标签的现有要求以外的错误情形如下:
-
如果 low 的值大于 high 的值,则编译器会拒绝代码并显示错误消息。由于其他编译器的行为不一致,因此,只有通过错误条件才能确保程序在由其他编译器编译时不会表现出不同的行为。
-
如果 case 标签的值在已在 switch 语句中使用的 case 范围内,则编译器会拒绝代码并显示错误消息。
-
如果 case 范围重叠,则编译器会拒绝代码并显示错误消息。
如果 case 范围的一个端点是数值,则在省略号 (...) 两侧留空格以避免其中一个点被视为小数点。
示例:
case 0...4; // error case 5 ... 9; // ok标签:case,...,编译器,switch,result,编码方式,范围 From: https://www.cnblogs.com/BlogLwc/p/5634934.html