作者cat99961 (阿湯)
看板C_and_CPP
標題[問題] 請問關於a=a++的問題
時間Thu Nov 3 17:06:33 2016
抱歉!想請問各位高手一個基本的問題..
我測試一個小小的程式碼的時候
其中
int a=0;
a=a++;
printf("%d",a);
結果是0
為什麼不是1
我的想法如下:
1.先做a=a,此時a=0
2.再執行a=a+1,此時a=1
但結果卻是0,和想的不同
請問各位大大,是甚麼原因呢?
感激不盡....
--
※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 118.232.225.26
※ 文章網址: https://webptt.com/m.aspx?n=bbs/C_and_CPP/M.1478163995.A.EAA.html
1F:→ aiwhat: undefined behavior 11/03 17:16
2F:→ ilms49898723: 置底13誡 no.8 11/03 17:17
3F:→ w347437: 先知道a++跟++a的差別吧 11/03 17:17
4F:→ w347437: a++是在整行程式結束(分號後)才做+1的動作,另外反之 11/03 17:19
5F:→ cat99961: 抱歉,第一次發文 11/03 17:22
6F:→ cat99961: 開發平台(Platform): (Ex: Win10, Linux, ...) Win10 11/03 17:23
7F:→ cat99961: 編譯器(Ex: GCC, clang, VC++...)+目標環境(跟開發平台 11/03 17:23
8F:→ cat99961: 不同的話需列出) DEVC++ 11/03 17:26
9F:推 wtchen: 置底13誡 no.8 哪裡看不懂? 11/03 17:27
10F:→ cat99961: 我知道a++和++a的區別,但是這個真的不一樣 11/03 17:27
11F:→ BSpowerx: 誰寫這種東西先把他開除掉 11/03 17:30
12F:→ cat99961: 我這個和置底13誡 no.8 的不同 11/03 17:30
13F:→ Schottky: 不是針對你,誰寫這種東西明天就不用來上班了+1 11/03 17:32
14F:→ Schottky: 這是 undefined behavior,你不能自己一廂情願 11/03 17:34
15F:→ Schottky: a++ 回傳 a 是沒錯,但assign和increase不見得誰先做 11/03 17:35
16F:→ Schottky: 這就是第八誡要告訴我們的事,唐僧就是要他徒弟記住這點 11/03 17:37
17F:→ cat99961: 抱歉!我致底13誡.no8有的地方沒看到 11/03 17:37
18F:→ cat99961: 不過我覺得很奇怪,因為編譯可以過 11/03 17:38
19F:→ cat99961: 而且我看過以下的文章 11/03 17:38
21F:→ cat99961: 抱歉!我囉嗦了點...但我還是覺得很奇怪 11/03 17:39
22F:推 shadow0326: 這文好屌 已跪 11/03 17:39
23F:推 shadow0326: 原po可以先google什麼是undefined behavior 11/03 17:41
24F:→ hn12404988: a += 1 11/03 17:47
25F:→ james732: 置底第8誡有跟你說編譯會不過嗎?XD 11/03 17:47
26F:→ cat99961: 我上網查了undefined behavior,了解了.. 11/03 17:48
27F:→ cat99961: 感謝各位.. 11/03 17:48
28F:→ Schottky: 我剛剛試了一下,gcc (Dev C++) 加 -Wall 會有 warning 11/03 17:52
29F:推 stupid0319: 這問題跟雞生蛋還是蛋生雞一樣 11/03 18:33
30F:→ Littlechozy: 就算有置底這個問題還是常常冒出來...以後是不是每本 11/03 18:35
31F:→ Littlechozy: 教科書或程式課一開始就先教這個算了 11/03 18:36
32F:→ Littlechozy: 或者考慮一下把它常駐板標呢XDD 11/03 18:37
33F:→ wtchen: 大學有在教undefined behavior嗎? 11/03 19:24
34F:→ Schottky: 記得我們系的大一計程有教 11/03 19:40
35F:→ wtchen: 我想把13誡加個第0誡講undefined behavior好了 11/03 19:52
36F:→ Caesar08: 我大一的時候沒有教 11/03 19:54
37F:→ pttworld: 可以嘗試a=(a++),不過仍是不建議的寫法。 11/03 20:45
38F:→ Caesar08: 或是你可以使用C++17的compiler.. 11/03 21:04
39F:→ cat99961: 我大學沒教undefined behavior 11/03 22:01
40F:→ cat99961: 感謝各位...長了許多知識 11/03 22:02
41F:推 hakman: 這個問題真的是蠻常出現的,大概一個月一次 Orz 11/03 23:21
42F:→ hakman: 不過我也是來這個版之後才知道的 Orz 11/03 23:21
43F:推 Yshuan: 不是一句大學沒教的問題... 11/04 00:15
44F:→ cat99961: 我那句是在回答wtchen的提問啦... 11/04 00:28
45F:→ Schottky: 解釋一下,明天不用來上班的原因是這種 bug 極度難抓 11/04 01:35
46F:→ Schottky: 所以大家都已經訓練有素,看見類似的寫法立刻窮追猛打 11/04 01:36
47F:→ Schottky: code review 時看見,不管執行結果對不對先開罵再講 11/04 01:37
48F:→ Schottky: 因為就算目前執行結果是對的,不立刻改正以後可能會出錯 11/04 01:38
49F:→ Schottky: 前面有人說在分號後才做,其實在複雜算式裡不一定是這樣 11/04 01:41
50F:→ Schottky: 而且複雜算式的未定義行為可能 compiler 也抓不出來 11/04 01:42
51F:推 steve1012: 根本就沒差那一行 有什麼必要寫這樣? 11/04 02:34
52F:→ jacky1989: 我也習慣寫成a+=1,比較能預知行為 11/04 22:32
53F:推 Ommm5566: 開除+1 不要說不懂未定義 連++功能都不清楚是哪招 11/05 08:42
54F:推 michael0728n: 就算有括號起來應該也還是UB? 不是很確定XD 11/05 16:50
55F:→ Schottky: @michael0728n 括起來一樣是 undefined behavior 無誤 11/05 16:54
56F:推 wtchen: 在C++, a = ++a OK, a=a++不行 (左值跟右值的問題) 11/05 17:01
57F:→ wtchen: 不過就算是C+我還是不希望看到這種code.... 11/05 17:01
58F:推 michael0728n: 偷問一下,樓上的前者為何可以?因為++a會產生斷點嗎 11/05 18:14
59F:→ michael0728n: *sequence point 11/05 18:15
60F:→ wtchen: 請看置底13誡-8,不過印象中C++11開始才能這麼搞 11/05 18:38
61F:→ wtchen: 有人要總結一下C++14/17針對這方面的修改嗎? 11/05 18:40
62F:推 michael0728n: 懂了,概念停在C++03,難怪看置底感覺怪怪 11/06 09:21
63F:→ michael0728n: 置底好像改好了,謝謝版主~ 11/06 09:22
64F:推 wtchen: 因為板工很少用C++,愈來愈複雜 @@ 11/06 17:17
65F:推 deangood01: 感覺需要拆板了~ 11/06 19:23