- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我的代码中有这个 switch 语句:
switch(buttonIndex){
case 0:
[actionSheet dismissWithClickedButtonIndex:buttonIndex animated:YES];
break;
case 1:
UIImagePickerController *imagePicker = [[UIImagePickerController alloc] init];
imagePicker.delegate = self;
imagePicker.sourceType = UIImagePickerControllerSourceTypeCamera;
[self presentModalViewController:[imagePicker autorelease] animated:YES];
break;
default:
[self openEmailViewInViewController:self];
}
error:expected expression before 'UIImagePickerController'
最佳答案
我遇到了这个问题,有一天我决定深入研究它。
简短的非回答但务实的解决方案:
解决这个“问题”的一种方法是使用分号,;
, 紧跟在 case ...:
的冒号之后陈述。例如,使用您提供的示例,它可以是“固定的”,因此它的编译和行为就像您直觉上期望的那样:
case 1:; // <- Note semi-colon.
UIImagePickerController *imagePicker = [[UIImagePickerController alloc] init];
imagePicker.delegate = self;
declaration
, 语句是
statement
. A
statement
意味着多种事物,其中之一被称为
compound-statement
,就是熟悉的
{ ... }
堵塞。
...
部分松散地定义为
zero or more
block-items
, 带有
block-item
被松散地定义为
either a
declaration
or a
statement
.
labeled-statement
的方式上(一个 goto 标签、case 标签或
default:
,本质上是
...:
语句)被定义,它是松散定义的
...: zero or more
statements
.正如人们直觉所料,它不是
zero or more
statements
or
declarations
.使用
;
紧跟在
labeled-statement
之后s
:
基本上终止了
zero or more
statements
labeled-statement
的一部分.这会导致语法回退到
compound-statement
定义,它允许下一个“语句”是
statement
或
declaration
.
labeled-statement
可以匹配
case 1: case 2: case 3:
.用过于简单的术语
(1)
,某些类型的语法递归简单且“无歧义”,而另一些则复杂且“有歧义”。为简单起见,大多数语言工具只会处理必须通过查看“下一个标记”来确定性地解决任何歧义的情况。我提到这一点只是因为虽然这在直觉上看起来像是 C99 规范中的一个缺陷,但可能存在令人信服的、非显而易见的原因......而且我没有费心对该主题进行任何进一步的研究以找出无论哪种方式。
(1)
这并不是技术上准确的描述,而是对于不熟悉所涉及问题的人的合理近似。
switch
case
s),但在一种情况下确实失败:当声明声明 C99
variable length array
时,这将不起作用,例如
case 1:; void *ptrs[count];
这是因为在 C99 中,“跳过”C99 VLA 的声明是错误的,该声明位于发生跳转的同一词法范围内。在这些情况下,您需要使用
case 1: { void *ptrs[count]; }
.在这种情况下,
ptrs
的范围VLA 在收盘时结束
}
.这比最初看起来更复杂,因为以下是完全合法的 C 代码,尽管乍一看,人们会直觉地认为它不是:
switch(3){
case 0:
printf("case 0\n");
break;
case 1:;
int *ip = NULL;
printf("case 1\n");
break;
case 2:
{
int ia[6];
printf("case 2\n");
break;
case 3:
printf("case 3\n");
break;
default:
printf("default\n");
}
}
case 3
.
关于iphone - Obj-C 中奇怪的开关错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1180550/
我正在尝试创建键值对并推送到数组,但我得到的只是 [Obj Obj]、[Obj Obj]。我创建了一个传递名称和值的函数,用于将键和值分配给 JavaScript 对象。这是我的代码。不确定我错过了什
似乎在 for 循环的上下文中,关于对象的语法发生了变化。 为什么 console.log() 不应该运行相同的东西?第一个按预期运行,第二个呈现错误“steve is not defined”: v
在 Ady Osmani 的 blog post关于 js 中的命名空间,他提到了 5 个常见做法来测试先前定义的命名空间/对象是否存在以防止覆盖。我在这里复制我关注的 3 个: var myAppl
有没有办法(我怀疑它涉及继承和多态)来区分OBJ o, OBJ& o, const OBJ& o?我希望在 3 个不同的程序中使用相同的代码,并使用相同的方法名称调用不同的方法。 int main()
我正在寻找一个正则表达式来分割这种内容: obj.method(obj.attr,obj.attr2) 我希望拆分返回一个数组: ["obj", "method(obj.attr, obj.attr2
我想知道这些方法中哪种更好: var Obj = Obj || {}; 或 if (Obj === undefined || typeof Obj !== 'object') { Obj = {}
我正在尝试将一个值推送到数组的属性,如下所示 var obj = {}; obj.a = (obj.a || []).push(10); console.log( typeof obj.a );
为了避免误解,我们首先要就某些词语的含义达成一致。以下含义并非普遍接受的含义,我仅建议将它们作为此问题的背景。 function -- Function 的一个实例。它有一个与其关联的过程。 obje
我总是不确定哪个是正确的以及该使用哪个。 通常我会进行(obj == null)检查。我认为最好直接问。 我应该使用以下哪一项: if (obj == null) { alert(
我正在处理一些使用 pygraph 模块的类,当我使用 add_node() 方法时,它总是出现“node xxx already in graph”。所以我尝试使用 deepcopy() 创建一个新
在 this page您可以看到以下示例,了解如何实现数组的indexOf: if (!Array.prototype.indexOf) { Array.prototype.indexOf = f
(1) 和 (2) 之间是否存在任何重要差异(语义、性能相关等)? var obj = obj || {}; var obj = Object(obj); 上下文。第一个是我在 Django 的模板和
我想知道 obj !== obj 什么时候可以为真? 这是我在书上看到的一行代码,我很纳闷。 var result = class2type[(obj == null || obj !== obj)]
我有时会看到这种模式...... obj.method.call(obj, arg) 我不明白为什么它不同于... obj.method(arg) 为什么要使用第一种模式? 我的天啊,似乎引起了很
我刚刚在一段 React 代码中发现了以下结构(名称已更改): 据我了解,bind 只是执行相应的函数,并将函数的 this 设置为第一个参数,并向其传递更多参数。由于 func 已经是我们想要的
当我们查看Underscore.js源码时,我们可以看到如下内容: _.isObject = function (obj) { return obj === Object(obj);
我在将项目发布到本地系统时收到此错误 Copying file obj\Debug\build.force to obj\Release\Package\PackageTmp\obj\Debug\bu
我有一个类型为 Expression> 的现有表达式;它包含类似 cust => cust.Name 的值. 我还有一个父类,其字段类型为 T .我需要一个接受上述作为参数并生成一个以父类 ( TMo
我在当前目录中有 add.c sub.c 并通过 makefile 编译它们。 我做了以下事情: program 1: objs=$(patsubst %.cpp, %.o, $(wildcard *
这个问题在这里已经有了答案: Is there a difference between copy initialization and direct initialization? (9 个回答)
我是一名优秀的程序员,十分优秀!