C_and_CPP 板


LINE

語言:CPP 今天寫quick sort的時候發現原本常用的交數值方法好像有觀念上的問題 https://i.imgur.com/GwH4NbM.png 我習慣的用法是第二十七行 直接用參考交換兩個值 但是發現印出來後都是一堆0 後來交叉比對後發現是XOR交換值的問題 想請問一下是不是陣列用XOR交換數值會出錯? 想請問一下原因 麻煩各位大大了 -- Talk is cheap. Show me the code. - Torvalds, Linus (2000-08-25). --



※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 163.22.18.105
※ 文章網址: https://webptt.com/m.aspx?n=bbs/C_and_CPP/M.1511406650.A.CFC.html
1F:推 Hazukashiine: One registeris is cheap. 11/23 11:42
2F:→ Hazukashiine: 認真回 那個你這個寫法啊 是 UB 喔 11/23 11:43
3F:→ Hazukashiine: 不能在同一個 SP 區間賦值兩次 11/23 11:44
4F:→ ptt0720: 請問UB是什麼意思 11/23 11:44
5F:→ Hazukashiine: Undefined Behavior 11/23 11:45
6F:→ ptt0720: 原來如此 我之前都這樣做 然後沒出錯 我以為可以這樣子 11/23 11:46
7F:→ Hazukashiine: 簡單說 要把異或賦值拆成三行寫才行 11/23 11:46
8F:→ ptt0720: https://i.imgur.com/qS5A6kA.png 這是原本寫法的記憶體 11/23 11:49
9F:→ ptt0720: 貼上來給大家參考 不要踩雷了 11/23 11:49
10F:→ stupid0319: 原本寫法的沒差啊!?a跟b的值對調了不是嗎 11/23 11:58
11F:→ ptt0720: 我也不清楚 求解答@@ 11/23 12:05
12F:→ ptt0720: 我原本的寫法交換完 記憶體不是對調 是不一樣 如圖 11/23 12:11
13F:→ ptt0720: 然後在main裡面記憶體少一個bit是因為0省略掉了? 11/23 12:12
14F:推 alan23273850: 要不要改成非陣列的寫法觀察看看,假設a,b,c,d之類 11/23 12:12
15F:→ alan23273850: 而且樓主30行是不是怪怪的 11/23 12:13
16F:推 CaptainH: 就算拆成三行,a=b 時會讓 a,b 都變成0 11/23 12:16
17F:→ ptt0720: 30行原本是SWAP 會印出一堆0 資料裡沒有0 11/23 12:24
18F:→ galic: 你推文那張圖是少了空白吧 位址明明一樣 11/23 12:29
19F:→ galic: xor swap 會 zero out 很明顯就是你x y 都是同一個「空間」 11/23 12:56
20F:→ galic: a b 11/23 13:01
21F:推 boss0405: warning: operation on 'a' may be undefined [-Wsequen 11/23 13:10
22F:→ boss0405: ce-point] 11/23 13:11
23F:推 peterwu4: 用mingw的c++幫你試,這樣換的過來~ 4.9.2 32bit環境 11/23 13:53
24F:→ galic: 就你i j index一樣會zero out,加個判斷式index一樣不用swa 11/23 14:30
25F:→ galic: p… 11/23 14:30
26F:→ ptt0720: 請問一下zero out是什麼意思 11/23 14:42
27F:→ ptt0720: index一樣會跑出零 謝謝大大解答 請問我要如何搜尋這方面 11/23 14:45
28F:→ ptt0720: 的知識 11/23 14:45
29F:→ ptt0720: q 11/23 15:12
30F:→ galic: zero out就是被清成0啦 XD 11/23 15:55
31F:推 peterwu4: xor自己XD 我晚惹~ 11/23 16:02
32F:推 LPH66: 雖然晚了, 我的 #1Deo3lyi 這篇也可參考一下 11/23 17:05
33F:→ LPH66: 然後如上面所說, 即使寫三條碰到 a b 同位置也會出事 11/23 17:06
34F:→ kingofsdtw: 你自己都看不懂了... 11/24 19:12
35F:→ kingofsdtw: 為何要寫一些要動腦的coding style? 11/24 19:12
36F:→ kingofsdtw: compiler會最佳化..別害同事 11/24 19:12
37F:推 steve1012: 效能瓶頸地方通常不是這個 swap… 11/25 02:48







like.gif 您可能會有興趣的文章
icon.png[問題/行為] 貓晚上進房間會不會有憋尿問題
icon.pngRe: [閒聊] 選了錯誤的女孩成為魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一張
icon.png[心得] EMS高領長版毛衣.墨小樓MC1002
icon.png[分享] 丹龍隔熱紙GE55+33+22
icon.png[問題] 清洗洗衣機
icon.png[尋物] 窗台下的空間
icon.png[閒聊] 双極の女神1 木魔爵
icon.png[售車] 新竹 1997 march 1297cc 白色 四門
icon.png[討論] 能從照片感受到攝影者心情嗎
icon.png[狂賀] 賀賀賀賀 賀!島村卯月!總選舉NO.1
icon.png[難過] 羨慕白皮膚的女生
icon.png閱讀文章
icon.png[黑特]
icon.png[問題] SBK S1安裝於安全帽位置
icon.png[分享] 舊woo100絕版開箱!!
icon.pngRe: [無言] 關於小包衛生紙
icon.png[開箱] E5-2683V3 RX480Strix 快睿C1 簡單測試
icon.png[心得] 蒼の海賊龍 地獄 執行者16PT
icon.png[售車] 1999年Virage iO 1.8EXi
icon.png[心得] 挑戰33 LV10 獅子座pt solo
icon.png[閒聊] 手把手教你不被桶之新手主購教學
icon.png[分享] Civic Type R 量產版官方照無預警流出
icon.png[售車] Golf 4 2.0 銀色 自排
icon.png[出售] Graco提籃汽座(有底座)2000元誠可議
icon.png[問題] 請問補牙材質掉了還能再補嗎?(台中半年內
icon.png[問題] 44th 單曲 生寫竟然都給重複的啊啊!
icon.png[心得] 華南紅卡/icash 核卡
icon.png[問題] 拔牙矯正這樣正常嗎
icon.png[贈送] 老莫高業 初業 102年版
icon.png[情報] 三大行動支付 本季掀戰火
icon.png[寶寶] 博客來Amos水蠟筆5/1特價五折
icon.pngRe: [心得] 新鮮人一些面試分享
icon.png[心得] 蒼の海賊龍 地獄 麒麟25PT
icon.pngRe: [閒聊] (君の名は。雷慎入) 君名二創漫畫翻譯
icon.pngRe: [閒聊] OGN中場影片:失蹤人口局 (英文字幕)
icon.png[問題] 台灣大哥大4G訊號差
icon.png[出售] [全國]全新千尋侘草LED燈, 水草

請輸入看板名稱,例如:Boy-Girl站內搜尋

TOP