• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            Heath's Blog

            There is no end, it is just the beginning! - A Game Developer's Notes

            邪惡的Windows

            眾所周知,WIN32 API分為Unicode版和非Unicode版,由于Unicode是后來加進來的,為了向下兼容,微軟的兄弟們使用了宏來統一接口,如MessageBox的定義:
            #ifdef UNICODE
            #define MessageBox  MessageBoxW
            #else
            #define MessageBox  MessageBoxA
            #endif // !UNICODE
            這個方法并不像看上去的那么完美,請看下面這段無辜的代碼:
            class MyClass
            {
             
            public:
                
            void MessageBox();
             
            }
            ;
            當項目中包含windows.h,更確切點說是winuser.h,如果未使用Unicode,在預編輯階段,MyClass::MessageBox會被替換成MyClass::MessageBoxA,而后讓人摸不著頭腦的編譯錯誤便跳了出來。據筆者經驗,與這些API同名的幾率其實很少,但正是因為少,當出現此種編譯錯誤時卻讓人不知如何是好。一種簡單的解決方法便是在MyClass頭文件中undef掉MessageBox:
            #ifdef MessageBox
            #undef MessageBox
            #endif

            posted on 2009-07-29 23:38 Heath 閱讀(2820) 評論(24)  編輯 收藏 引用 所屬分類: Programming Language

            Feedback

            # re: 邪惡的Windows 2009-07-29 23:44 安德斯

            換個名字撒,呵呵,難道情有獨鐘啊  回復  更多評論   

            # re: 邪惡的Windows 2009-07-30 00:28 紫夜蒼狼

            偶也覺得,換個名字就好了啊。  回復  更多評論   

            # re: 邪惡的Windows 2009-07-30 04:25 someone

            This is an overstatement. There are tons of defs in the system header files, why you don't complain about them?  回復  更多評論   

            # re: 邪惡的Windows 2009-07-30 08:36 貓貓

            說明微軟高啊
            微軟能把這么破的玩意組織了這么都年 ,你能說不好嗎?
            存在的就是合理的!  回復  更多評論   

            # re: 邪惡的Windows 2009-07-30 08:47 凡客誠品

            不錯啊!  回復  更多評論   

            # re: 邪惡的Windows[未登錄] 2009-07-30 09:08 Davy.xu

            干嘛用名詞當函數名,重名是肯定的  回復  更多評論   

            # re: 邪惡的Windows[未登錄] 2009-07-30 10:00 simon

            麻煩都是自找的,你開個命名空間不就是了  回復  更多評論   

            # re: 邪惡的Windows[未登錄] 2009-07-30 10:06 Bill Hsu

            謝謝LZ分享  回復  更多評論   

            # re: 邪惡的Windows 2009-07-30 11:18 abettor

            確實是很大的陷阱,這種宏很多,一不小心就掉井里。
            如果自己編程序的話,名字改了也就改了,即使改成阿貓阿狗也無所謂。但是如果是團隊開發,而且這些名字已經規定在了接口規范里,就不是那么容易改的了。
            況且,作為好的編程習慣,保持方法名的可讀性是非常重要的!  回復  更多評論   

            # re: 邪惡的Windows[未登錄] 2009-07-30 12:55 cc

            這種編譯錯誤很好找,博主不會看不懂錯誤提示吧  回復  更多評論   

            # re: 邪惡的Windows 2009-07-30 12:58 zwp

            @simon
            宏是通殺啊,沒有用的。  回復  更多評論   

            # re: 邪惡的Windows 2009-07-30 17:15 岳陽

            命名空間  回復  更多評論   

            # re: 邪惡的Windows[未登錄] 2009-07-30 18:55 欲三更

            這個還真么注意到,放在命名空間里也會替換么?  回復  更多評論   

            # re: 邪惡的Windows 2009-07-31 09:02 fuckyou

            簡直是扯淡。  回復  更多評論   

            # re: 邪惡的Windows[未登錄] 2009-07-31 11:24 Heath

            @岳陽
            @fuckyou
            自己實踐去吧,別沒事在這里亂吐口水...  回復  更多評論   

            # re: 邪惡的Windows 2009-07-31 16:06 cyberamoeba

            存在就是合理。在 Windows 平臺上寫東西,這種錯誤不應該犯。就像你用 C 寫程序,你總不能要求用 do 當函數名是應該被接受的。  回復  更多評論   

            # re: 邪惡的Windows[未登錄] 2009-07-31 16:46 Heath

            @cyberamoeba
            呵呵,這句話真有意思,你能像記住C語言關鍵字那樣記住那么多Windows API嗎?當你發現自己連命名一個SetPort函數的權力都沒有的時候,你還會這樣想嗎?上面例子中的MessageBox,當然是個人都知道。  回復  更多評論   

            # re: 邪惡的Windows[未登錄] 2009-07-31 17:25 hdqqq

            你有命名MessageBox的權利,條件是別去包含 <windows.h>
            既然你包含了這個文件,那就乖乖換名字吧。  回復  更多評論   

            # re: 邪惡的Windows 2009-07-31 23:08 路過

            我也遇到過類似的問題,當時沒有細究,只是重新命名了,原來是宏的問題。。。  回復  更多評論   

            # re: 邪惡的Windows 2009-08-01 14:27 wof

            @hdqqq
            undef掉MessageBox,直接調用MessageBoxA或者MessageBoxW不就行啦,真是OUT得不行了。。。  回復  更多評論   

            # re: 邪惡的Windows[未登錄] 2009-08-05 08:53 Alex

            你認為windows該怎么做才能做到兼容ascii和Unicode呢?自己定義的函數加個項目名稱或者單位的前綴都是不錯的。看看jni生成的c接口  回復  更多評論   

            # re: 邪惡的Windows 2009-08-05 15:22 陳梓瀚(vczh)

            既然你知道了原因,那出現了這個錯誤信息你肯定立刻就反應過來的了。  回復  更多評論   

            # re: 邪惡的Windows 2009-12-05 21:32 parkerzhu

            編譯器應該負責  回復  更多評論   

            # re: 邪惡的Windows 2010-09-22 21:01 路過

            剛才測試過,在vs2008中,用了命名空間是不會有問題的。。。  回復  更多評論   

            伊人久久精品线影院| 久久久久亚洲av无码专区喷水| 精品综合久久久久久97超人| 伊人久久精品线影院| 亚洲欧洲久久久精品| 久久精品国产99国产精品亚洲 | 国内精品久久久久久野外| 热久久这里只有精品| 日日狠狠久久偷偷色综合免费 | 亚洲色欲久久久综合网东京热| 久久人人妻人人爽人人爽| 亚洲欧美精品伊人久久| 久久久精品久久久久影院| 国产亚洲欧美成人久久片 | 色欲综合久久躁天天躁蜜桃| 99久久99这里只有免费费精品| 99热成人精品免费久久| 亚洲色婷婷综合久久| 久久亚洲中文字幕精品一区四 | 久久久久亚洲精品天堂久久久久久| 亚洲精品美女久久久久99| 99热精品久久只有精品| 久久精品亚洲日本波多野结衣| 亚洲国产高清精品线久久| 9191精品国产免费久久| 亚洲中文字幕无码一久久区| 久久露脸国产精品| 99久久精品九九亚洲精品| 粉嫩小泬无遮挡久久久久久| 99精品国产99久久久久久97| 久久精品国产男包| 久久综合久久伊人| 久久亚洲视频| 久久精品国产亚洲一区二区三区| 国产精品岛国久久久久| 亚洲AV日韩精品久久久久久| 久久精品国产免费观看| 久久天天躁狠狠躁夜夜不卡| 一日本道伊人久久综合影| 久久亚洲日韩看片无码| 久久精品国产2020|