C_and_CPP 板


LINE

開發平台(Platform): (Ex: Win10, Linux, ...) Linux 編譯器(Ex: GCC, clang, VC++...)+目標環境(跟開發平台不同的話需列出) GCC 額外使用到的函數庫(Library Used): (Ex: OpenGL, ...) 問題(Question): 我看到了一個奇怪的位反轉程式 看他用for loop跑得很忙 但看一看感覺他實際效果只是將代入的x值往右shift一次 然後將第31位元開始的左邊都濾掉,最後將結果餵給y去return 為何他不乾脆簡單的寫return (x >> 1) & 4294967295就好了呢? 卻要寫得這麼複雜? (而且,這樣的動作也不是位反轉吧?...這函式如此命名,但一點注解都沒有...) 請問我是不是誤會了什麼? 或是沒注意到這function的真正意義? 真的非常謝謝各位 程式碼(Code):(請善用置底文網頁, 記得排版) 好讀版: http://codepad.org/pzWWrf55 純文字版: unsigned long bitreverse(unsigned long x) { int i; unsigned long y = 0; for (i = 0; i < 32; i++) { y <<= 1; y |= (x >> (32 - i)) & 1; } return y; } 補充說明(Supplement): --



※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 220.130.45.196
※ 文章網址: https://webptt.com/m.aspx?n=bbs/C_and_CPP/M.1519630902.A.AA8.html
1F:→ asilzheng: 你人腦在跑程式時是不是忘了做for-loop? 02/26 16:02
大大我有個疑問 既然這function並不需要可變的loop之類(過程很固定),寫成for loop也沒有更容易讀 為何不寫成 #define SET_BIT_32_TO_63_BE_ZERO 4294967295 return x >> 1 & SET_BIT_32_TO_63_BE_ZERO 這樣是不是效率更好且易懂呀? 我也擔心我這樣理解這個function是不是錯誤的? 如果改寫會出現BUG?
2F:推 cutekid: y |= (x >> (31 - i)) & 1; 是不是要 31 - i 才對 ? 02/26 16:10
大大,我一開始也一直在思考,他應該是要反轉吧? 0001變1000這樣 如果要反轉,就不應該位移32個bit,也就是大大提到的,應該是31 - i不是32 - i 又如果他是要反轉,也不該是31或32 - i,直接使用i就達到反轉效果了 而且unsigned long在我的平台已經是64 bit了,所以他只想搞前32 bit XDD? 但我目前認了,就當做他不是要反轉了... 就當做他目前for loop的動作就是他刻意設計的,結果也是他要的 那我就在想,過程是不是也可以寫簡單一點? 這function目前寫法的真正行為,是不是就return (x >> 1) & SET_BIT_32_TO_63_BE_ZERO ※ 編輯: liwmewmew (220.130.45.196), 02/26/2018 16:56:01
3F:→ Hazukashiine: 先不管哪樣的寫法是對的 02/26 17:06
4F:→ Hazukashiine: 基本上這個 code 看到我就會先給一個大問號 02/26 17:06
5F:→ Hazukashiine: 首先 hard-code 32 在程式碼裡面 02/26 17:07
6F:→ Hazukashiine: 但是 unsigned long 並沒有保證一定是 32-bit 02/26 17:07
7F:→ Hazukashiine: 是不是應該用 uint32_t 或是用自定義 typedef? 02/26 17:08
8F:→ Hazukashiine: 另外一件事這個 function 的名稱: bitreverse 02/26 17:09
9F:→ Hazukashiine: 給我的第一印象就是:「有這麼多步驟嗎?」 02/26 17:09
10F:→ Hazukashiine: 我第一個直覺做 reverse 就是 x ^= ~(type)0; 02/26 17:10
11F:噓 sharkbay: 你是說 inverse 取反向 02/27 08:06
12F:→ sharkbay: Bit Twiddling Hacks 02/27 08:10
13F:→ sharkbay: 餵狗看看 02/27 08:10
14F:→ Hazukashiine: 喔喔喔喔 我弄錯了 感冒到腦子壞了 02/27 10:24







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燈, 水草

請輸入看板名稱,例如:BuyTogether站內搜尋

TOP