• <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>

            woaidongmao

            文章均收錄自他人博客,但不喜標(biāo)題前加-[轉(zhuǎn)貼],因其丑陋,見諒!~
            隨筆 - 1469, 文章 - 0, 評論 - 661, 引用 - 0
            數(shù)據(jù)加載中……

            使用namespace的正確方法


            來自:www.codeproject.com
            標(biāo)題: Using Namespaces Properly
            命名空間(namespace)在C++中的作用非同一般。本文目的不在于闡述命名空間的語法,而在于演示命名空間的使用方法,或者說是使用命名空間的小竅門。
            命名空間可以簡單的將一些命名(name)用另一個命名打包封裝起來。比方說:

            namespace net {
                class Socket {
                    ...
                };
            }
            ...
            net::Socket socket;
            
            經(jīng)過這樣的封裝以后,如果在兩個庫(library)都實現(xiàn)了Socket類,只要它們命名空間的名字不同,你就可以同時使用它們而沒有任何命名上的沖突。
            但這樣做還是有問題:假如兩個公司都要寫一個network庫,那么當(dāng)她們編寫代碼的時候都使用Socket命名他們的類的可能性有多大?我猜是接近100%。

            命名空間的名字最好是方便輸入的,就是說命名空間的名字最好別太長了,2-4個字符就可以了。抱著這樣的想法,那兩個公司把他們的命名空間叫做net的機會又是多大呢?5%還是10%?

            不難看出,命名空間并沒有解決所有問題,它只是使發(fā)生命名沖突的機會相對小了而已。

            有一種叫做“工業(yè)化長度”的方法(Industrial Strength Solution),這種方法在命名namespace的時候使用長的唯一的名稱,而在程序里使用短的別名。如此network庫就可能會是這個樣子:

             

            namespace net_33843894 {
                class Socket {
                    ...
                };
            }
            
            net_后面的數(shù)字是由一個隨機數(shù)產(chǎn)生器產(chǎn)生的。為了以后描述方便,這里我們假定上面的代碼是放在<netlib>頭文件里。
            用戶使用我們的庫的時候,就要編寫他自己的頭文件<mynetlib>,包含下面的內(nèi)容:
            #include <netlib>
            namespace net = net_33843894;
            
            
            他創(chuàng)建了一個在本工程內(nèi)有效的別名,用來代表提供給他的庫中的命名空間。如果名稱net已經(jīng)被別的庫使用了,那么他還可以另選一個名字代替,例如:net2,sock,或者別的什么。

            這樣就萬事大吉了么?還沒有。你還要做一件事:使你的庫用起來更簡單、更方便。在這個講究完美的社會里,人們雙擊一個安裝文件后,你的庫在他們的開發(fā)環(huán)境里就應(yīng)該是可用的,接下來就是#include <netlib>,再接下來他們就可以去忙別的了。

            然而,現(xiàn)在的情況是,用戶為了使用你的庫需要創(chuàng)建一個他自己的頭文件,雖然這并沒有什么大不了的,但不是每個用戶都能忍受這一點。解決的方法就是直接提供一個合理的缺省值,如果用戶覺得不合適也可以取消,所以,在你的頭文件里使用預(yù)編譯選項,如下:

            namespace net_33843894 {
                class Socket {
                    ...
                };
            }
            
            #ifndef NO_NET_33843894_ALIAS
                namespace net = net_33843894;
            #endif
            
            這樣我們就給命名空間的名字提供了一個缺省值,如果這個名字已經(jīng)有人用了,那么用戶可以定義一個NO_NET_33843894_ALIAS宏,別名就會被取消。

            不幸的是,即使是使用了短的別名net,當(dāng)你使用Socket類的方法不對的時候,在我所用過的編譯器中,沒有一個能夠在錯誤提示信息里顯示的短的別名,而是仍然使用net_33843894::Socket。讀起來有些費勁。

            怎么辦?看我的。

            #ifdef NO_NET_33843894_ALIAS
            namespace net_33843894 {
            #else
            namespace net {
            #endif
                class Socket {
                    ...
                };
            }
            
            #ifndef NO_NET_33843894_ALIAS
                namespace net_33843894 = net;
            #endif
            
            如果沒有定義宏NO_NET_33843894_ALIAS, 就直接給命名空間起個短一點的名字,把別名弄長點就可以了。這樣,錯誤信息讀起來就會順眼多了。

            posted on 2008-05-09 14:52 肥仔 閱讀(356) 評論(0)  編輯 收藏 引用 所屬分類: C++ 基礎(chǔ)

            午夜精品久久久久久久久| 国产精品热久久无码av| 精品无码久久久久久久动漫| 久久乐国产精品亚洲综合| 久久精品国产精品亚洲精品| 久久99国产精品一区二区| 亚洲精品WWW久久久久久| 久久最近最新中文字幕大全| 久久人人爽人人人人爽AV | 久久这里只精品国产99热| 狠狠精品干练久久久无码中文字幕| 亚洲伊人久久成综合人影院| 国产精品久久久亚洲| 亚洲av成人无码久久精品| 久久国产成人午夜aⅴ影院 | 久久中文字幕人妻熟av女| 久久久久99精品成人片| 精品久久国产一区二区三区香蕉| 少妇久久久久久久久久| 亚洲欧美日韩精品久久亚洲区 | 欧美伊人久久大香线蕉综合 | 91精品国产色综合久久| 一本一本久久a久久综合精品蜜桃| 久久综合亚洲色HEZYO国产| jizzjizz国产精品久久| 久久婷婷五月综合色奶水99啪| 久久本道久久综合伊人| 色综合色天天久久婷婷基地| 国产精品对白刺激久久久| 久久精品天天中文字幕人妻| 久久无码av三级| 国产成人精品久久免费动漫| 久久久久久久亚洲Av无码| 7777久久久国产精品消防器材| 亚洲国产精品无码久久久久久曰| 久久久91人妻无码精品蜜桃HD| 99久久精品无码一区二区毛片 | 亚洲国产精品久久久久婷婷软件| 精品久久香蕉国产线看观看亚洲| 69SEX久久精品国产麻豆| 久久精品中文闷骚内射|