• <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 閱讀(2831) 評論(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中,用了命名空間是不會有問題的。。。  回復  更多評論   

            久久黄色视频| 少妇内射兰兰久久| 久久www免费人成精品香蕉| 久久天天躁狠狠躁夜夜不卡| 无码人妻精品一区二区三区久久| 日本欧美久久久久免费播放网 | 欧美成人免费观看久久| 99精品国产综合久久久久五月天| 久久成人精品视频| 2021国产精品午夜久久| yellow中文字幕久久网| 热99RE久久精品这里都是精品免费| 国产亚洲欧美成人久久片| 久久精品免费全国观看国产| 99久久精品免费国产大片| 色综合久久久久久久久五月| 久久无码AV中文出轨人妻| 国产激情久久久久影院老熟女免费| 无码人妻久久久一区二区三区| 久久久久97国产精华液好用吗| 99久久人妻无码精品系列蜜桃| 婷婷久久综合| 久久久91人妻无码精品蜜桃HD| 国产精品一区二区久久| 亚洲精品无码久久久影院相关影片 | 久久国产成人亚洲精品影院| 久久亚洲精品中文字幕三区| 久久国产乱子伦免费精品| 人妻少妇久久中文字幕| 久久WWW免费人成一看片| 久久婷婷色香五月综合激情| 久久99精品国产99久久6| 伊人久久大香线蕉精品| 99久久精品国内| 久久精品国产福利国产秒| 久久精品国产99国产精品澳门| 久久福利青草精品资源站| 国产69精品久久久久99| 久久福利片| 狠狠色婷婷久久综合频道日韩| 久久99久久99精品免视看动漫|