向各位请教一个代码问题

2010-07-25 06:44:29 +08:00
 Livid
http://gist.github.com/489051

在 Xcode 中新建一个 command line tool (Foundation),然后把上面的代码粘贴进去,然后运行。

同样的逻辑如果是在 gcc -o hello hello.c 里的话是输出两个 5050,而在这里是 5050 10100。

谁能解释一下为什么吗?
4829 次点击
所在节点    iDev
11 条回复
airwolf
2010-07-25 07:01:38 +08:00
int foo(int start, int end) {
int result = nil;

int i;

int max = end + 1;

for (i = start; i < max; i++) {
result = result + i;
}

return result;
}

这样貌似就好了,虽然会有 warninig ...
Livid
2010-07-25 07:04:10 +08:00
Objective-C 和 C 的函数变量的生命周期不一样么?

如果把上面的代码用 C 写,只需要把 NSLog() 换成 printf(),然后得到的就是两个 5050。
airwolf
2010-07-25 07:14:51 +08:00
嗯,或者说处理的方式不一样?

感觉 Objc 有的地方很拖泥带水,必须手动清理先(虽然我不理解深入的,只是感觉)
ashchan
2010-07-25 09:22:35 +08:00
foo 函数中的result未初始化,结果永远是不可预料的。gcc可能自动将它初始化为0了。

这跟作用域没什么关系。

解决方法是改为 int result = 0;
Livid
2010-07-25 09:32:35 +08:00
@ashchan

嗯,我知道让 result = 0 可以得到期望的结果,但是……

http://gist.github.com/489173

那么你再试试这个。

看看 Hello 和 5050 输出的顺序,这也是我没法理解的。
lizdo
2010-07-25 11:09:26 +08:00
我这边好像没啥不对的呀
2010-07-25 11:05:49.221 Bug[5133:a0f] Hello
2010-07-25 11:05:49.257 Bug[5133:a0f] Hello
2010-07-25 11:05:49.257 Bug[5133:a0f] result1: 5050
2010-07-25 11:05:49.258 Bug[5133:a0f] result2: 5050

先Call的foo(), 所以先打的Hello嘛
Livid
2010-07-25 11:18:25 +08:00
哦,抱歉。

第二个是我晕了,确实没有任何问题。
Livid
2010-07-25 11:19:47 +08:00
第一个:

http://gist.github.com/489051

在我的机器上运行的结果是:

2010-07-25 11:19:36.250 HelloWorld[2906:a0f] result1: 5050
2010-07-25 11:19:36.253 HelloWorld[2906:a0f] result2: 10100
ashchan
2010-07-25 12:25:25 +08:00
在不同的机器上跑结果会不同的,@livid可以试试在Xcode 4里测一下,我这跟3下面不同。我还是认为未初始化变量是一种编程错误,不需要纠结会出来不正确的结果值吧?;-)
huahang
2010-07-25 16:59:29 +08:00
C和C++的Spec里面,都没有指定说int型的默认构造器会把值初始化为零。
huahang
2010-07-25 16:59:59 +08:00
所以哪怕第一个函数返回了5050,也是侥幸。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/889

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX