• <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是后來加進來的,為了向下兼容,微軟的兄弟們使用了宏來統(tǒng)一接口,如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,而后讓人摸不著頭腦的編譯錯誤便跳了出來。據(jù)筆者經驗,與這些API同名的幾率其實很少,但正是因為少,當出現(xiàn)此種編譯錯誤時卻讓人不知如何是好。一種簡單的解決方法便是在MyClass頭文件中undef掉MessageBox:
            #ifdef MessageBox
            #undef MessageBox
            #endif

            posted on 2009-07-29 23:38 Heath 閱讀(2818) 評論(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

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

            # 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

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

            # 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 當函數(shù)名是應該被接受的。  回復  更多評論   

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

            @cyberamoeba
            呵呵,這句話真有意思,你能像記住C語言關鍵字那樣記住那么多Windows API嗎?當你發(fā)現(xiàn)自己連命名一個SetPort函數(shù)的權力都沒有的時候,你還會這樣想嗎?上面例子中的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呢?自己定義的函數(shù)加個項目名稱或者單位的前綴都是不錯的。看看jni生成的c接口  回復  更多評論   

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

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

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

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

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

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

            久久综合偷偷噜噜噜色| 一97日本道伊人久久综合影院| 国产精品久久久久免费a∨| 久久精品无码一区二区无码| yellow中文字幕久久网| 久久久久久毛片免费播放| 99精品国产在热久久| 久久久久久国产a免费观看黄色大片| 欧美亚洲国产精品久久高清| 久久发布国产伦子伦精品| 国产精品久久久久久久久久免费| 欧美一区二区久久精品| 99久久国产热无码精品免费久久久久| 久久人人爽人人爽人人片AV麻烦| 久久国产精品二国产精品| 97久久精品国产精品青草| 久久热这里只有精品在线观看| 狠狠狠色丁香婷婷综合久久俺| 久久99精品久久久久久hb无码 | 久久人人爽人人爽人人av东京热| 91精品国产高清91久久久久久| 亚洲а∨天堂久久精品9966| 久久精品18| 欧美日韩精品久久久免费观看| 久久久无码一区二区三区| 久久强奷乱码老熟女网站| 看全色黄大色大片免费久久久| 久久婷婷五月综合97色直播| 国产精品99精品久久免费| 久久天堂AV综合合色蜜桃网| av无码久久久久久不卡网站| 久久精品国产免费观看| 亚洲国产成人久久一区WWW| 久久乐国产精品亚洲综合| 品成人欧美大片久久国产欧美| 久久精品国产99国产电影网| 久久99精品国产一区二区三区| AV无码久久久久不卡网站下载| 俺来也俺去啦久久综合网| 精品免费tv久久久久久久| 99久久综合国产精品二区|