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

            公告

            <2025年8月>
            272829303112
            3456789
            10111213141516
            17181920212223
            24252627282930
            31123456

            統計

            • 隨筆 - 9
            • 文章 - 13
            • 評論 - 3
            • 引用 - 0

            常用鏈接

            留言簿(1)

            隨筆分類

            隨筆檔案

            文章分類

            文章檔案

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            為什么靜態成員函數的外部“C”聲明是被禁止的

            函數原型里的外部“C”聲明強制要求用于該函數的C連接(C linkage),而不是缺省的C++連接(C++ linkage)。這就意味著C連接會保證可以從使用其它編程語言寫成的模塊里調用一個函數??例如C、Fortran和COBOL??因為函數名是以一種大多數非C++的編譯器和連接器都很熟悉的方式修飾的。

            一個有趣的問題是,將靜態成員函數的聲明作為外部“C”是否被允許。例如:

            struct C
            {
            ??extern "C" static void f(int); // valid?
            };

            答案是不行。C++的標準是不允許成員函數,不論是靜態的還是非靜態的,被作為外部“C”聲明。第一眼看上去,這個決定似乎過于嚴厲,因為你會把指向靜態成員函數的指針作為普通函數的指針來對待,如下面的例子所示:

            void (*pf) (int) = &C::f; // OK

            名稱修飾

            你不能將靜態成員函數作為外部“C”來聲明有一個很合理的理由:名稱修飾(也叫做name mangling)。C++的名稱修飾是編譯器將函數的名稱轉變成為一個唯一的字符串的過程,這個字符串會對函數的類、其命名空間、其參數表,以及其他等等進行編碼。C++的命名修飾適用于靜態成員函數,也適用于非靜態成員函數。靜態函數的命名修飾的一個好處之一,是能夠在不同的類里使用同一個名稱來聲明兩個或者更多的靜態成員函數??而不會發生名稱上的沖突。考慮一下下面的情況:

            struct C
            {
            ??static void f(int);
            };
            struct D
            {
            ??static void f(int); // doesn't clash with C::f
            };

            f()的外部“C”聲明會禁止命名修飾;如果它被允許的話,那么不同類里具有相同名稱的靜態成員函數就會相互沖突。它的不足之處是,你不能從使用其它語言寫成的模塊里調用這些函數,因為它們有C++連接。]

            =========================================================

            本文作者Danny Kalev 是一個系統分析家、軟件工程師,在C++和面向對象設計方面有著14年的專業經驗。

            posted on 2006-08-25 15:03 blues 閱讀(278) 評論(0)  編輯 收藏 引用

            久久综合给合久久国产免费| 国内精品伊人久久久久网站| 伊人色综合九久久天天蜜桃| 99久久99久久精品国产片果冻| 久久香蕉超碰97国产精品 | 久久综合九色综合欧美狠狠| 久久国产精品-久久精品| 久久99精品国产麻豆不卡| 久久亚洲日韩看片无码| 人人狠狠综合久久亚洲88| 97香蕉久久夜色精品国产| 99久久精品九九亚洲精品| 伊人久久综合精品无码AV专区| 日韩精品久久久久久| 亚洲精品国产美女久久久| 久久精品国产一区二区电影| 国内精品久久久久伊人av| 久久人人爽人人人人片av| 亚洲乱亚洲乱淫久久| 精品无码久久久久久尤物| 亚洲伊人久久综合影院| 88久久精品无码一区二区毛片 | 久久精品国产亚洲AV麻豆网站| 久久久久久久综合日本| 久久午夜电影网| 国产精品一区二区久久| 久久男人Av资源网站无码软件| 久久只这里是精品66| 一本色道久久综合狠狠躁篇| 久久综合久久性久99毛片| 青青草国产精品久久久久| 久久久久久综合一区中文字幕| 精品多毛少妇人妻AV免费久久| 久久国产午夜精品一区二区三区| 色偷偷888欧美精品久久久| 国内精品久久国产大陆| 99久久99这里只有免费的精品| 久久人爽人人爽人人片AV| 精品综合久久久久久888蜜芽| 精品久久久久久无码专区| 久久狠狠色狠狠色综合|