青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

huaxiazhihuo

 

C++的非侵入式接口

終于寫到c++的非侵入式接口了,興奮,開心,失望,解脫,…… 。在搞了這么多的面向對象科普之后,本人也已經開始不耐煩,至此,不想做太多闡述。

雖然,很早就清楚怎么在c++下搞非侵入式接口,但是,整個框架代碼,重構了十幾次之后,才終于滿意。支持給基本類型添加接口,好比int,char,const char*,double;支持泛型,好比vector,list;支持繼承,基類實現的接口,表示子類也繼承了對該接口的實現,而且子類也可以拒絕基類的接口,好比鴨子拒絕基類鳥類“會飛”,編譯時報錯;支持接口組合;……,但是,這里僅僅簡單介紹其原理,并不涉及C++中各種變態細節的處理,C++中,但凡是要正兒八經的稍微做點正事,就要面臨無窮無盡的細節糾結。

先看看其使用例子:

1、自然是定義一個接口:取之于真實代碼片段

    struct IFormatble
    {
        static TypeInfo* GetTypeInfo();
       
virtual void Format(TextWriter& stream, const FormatInfo& info) = 0;
        
virtual bool Parse(TextReader& stream, const FormatInfo& info)
        {
            PPNotImplement();
        }
    };

2、接口的實現類,假設為int添加IFormatble的接口實現,實際代碼肯定不會這樣對一個一個的基本類型來寫實現類的代碼。這里只是為了舉例說明。類的名字就隨便起好啦,

    struct ImpIntIFormatble : IFormatble
    {
        
int* mThis;    //這一行是關鍵
        virtual void Format(TextWriter& stream, const FormatInfo& info)override
        {}

        
virtual bool Parse(TextReader& stream, const FormatInfo& info)override
        {}
    };

這里的關鍵是,實現類的字段被規定死了,最多只能包含3個指針成員字段,且第1個字段一定是目的類型指針,第二是類型信息對象(用于泛型),第三是額外參數,次序不能亂。成員字段如果不需要用到第二第三個成員字段數據,可以省略不寫,好比這里。所有接口實現類必須遵守這樣的內存布局;

3、裝配,將接口的實現類裝配到現有的類上,以告訴編譯器該類對于某個接口(這里為IFormatble)的實現,用的是第2步的實現類ImpIntIFormatble

PPInterfaceOf(IFormatble, int, ImpIntIFormatble);

 

4、將實現類注冊到類型信息的接口實現列表中,這一步可以省略,只是為了運行時的接口查詢,相當于IUnknownQuery。這一行代碼是在全局對象的構造函數中執行的,放在cpp源文件中

RegisterInterfaceImp<IFormatble, int>();
然后就可以開開心心地使用接口了,比如
            int aa = 20;
            TextWriter stream();
            FormatInfo info();
            TInterface
<IFormatble> formatable(aa); //TInterface這個名字過難看,也沒辦法了
            formatable
->Format(stream, info);
            
double dd = 3.14;
            formatable 
= TInterface<IFormatble>(dd);    //假設double也實現IFormatble
            formatable->Format(stream, info);

是否有點神奇呢?其實也沒什么,不過就是在trait和內存布局上做文章,也就只是用了類型運算的伎倆。考察ImpIntIFormatble的內存布局,對于普遍的c++編譯器來說,對象的虛函數表指針(如果存在的話),都放在對象的起始地址上,后面緊跟對象本身的成員數據字段,因此,ImpIntIFormatble的內存布局相當于,

struct ImpIntIFormatble
{
    
void* vtbl;
    
int* mThis;
};

 

注意,這里已經沒有繼承了。這就是,實現了IFormatble 接口的ImpIntIFormatble對象的內存表示。因此,可以想象,所有的接口實現類的內存布局都強制規定為以下形式:

    struct InterfaceLayout
    {
        
const void* mVtbl;
        
const void* mThis;            //對象本身
        const TypeInfo* mTypeInfo;    //類型信息
        const void* mParam;    //補充參數,一般很少用到
    };

當然,如果編譯器的虛函數表指針不放在對象起始地址的話,就沒法這么玩了,那么非侵入式接口也無從做起。然后,就是TInterface了,繼承于InterfaceLayout

    template<typename IT>
    
struct TInterface : public InterfaceLayout
    {
        typedef IT interface_type;
        static_assert(is_abstract
<IT>::value, "interface must have pure function");
        static_assert(
sizeof(IT) == sizeof(void*), "Can't have data");
    
public:
        interface_type
* operator->()const
        {
            interface_type
* result = (interface_type*)(void*)this;
            
return result;
        }
        
    };

不管怎么說都好,TInterface對象的內存布局與接口實現類的內存布局一致。因此操作符->重載函數才可以粗暴的類型轉換來順利完成。然后構造TInterface對象的時候就是強制獲取ImpIntIFormatble對象的虛函數表(也就是其起始地址的指針數據)指針賦值給InterfaceLayoutmVtbl,進而依次把實際對象的指針放在mThis上,獲取到類型信息對象放在mTypeInfo中,如果有必要搭理mParam,也相應地賦值。

然后,就是template<typename Interface, typename Object>struct InterfaceOf各種特化的運用而已,就不值一提了。

由于c++abi沒有統一標準,并且,c++標準也沒有規定編譯器必須用虛函數表來實現多態,所以,這里的奇技淫巧并不能保證在所有平臺上都能夠成立,但是,非侵入式接口真是方便,已經是本座寫c++代碼的核心工具,一切都圍繞著非侵入式接口來展開。

原本打算長篇大論,也只有草草收場。之后,本座就解放了,會暫時離開cppblog很久,計劃中的內容,消息發送,虛模板函數,字符串,輸入輸出,格式化,序列化, locale,全局變量,模板表達式,組合子解析器,allocator,智能指針,程序運行時,抽象工廠訪問者等模式的另類實現,以求從全新的角度上來表現C++的強大,也只能中斷了。








posted on 2017-07-15 17:01 華夏之火 閱讀(2947) 評論(2)  編輯 收藏 引用 所屬分類: c++技術探討

評論

# re: C++的非侵入式接口 2017-07-17 11:03 天下

cppblog人氣不旺啊,
csdn還不錯,
現在都懶的寫blog了,唉.
  回復  更多評論   

# re: C++的非侵入式接口 2017-07-28 09:43 萬連文

確實沒必要在普及這些知識了,時代變了。雖然道理不會變,但是誰有在意這些呢?  回復  更多評論   

導航

統計

常用鏈接

留言簿(6)

隨筆分類

隨筆檔案

搜索

積分與排名

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            国产酒店精品激情| 亚洲欧美韩国| 亚洲一区三区视频在线观看| 亚洲黄色天堂| 亚洲精品国精品久久99热| 亚洲激情黄色| 一区二区三区精品久久久| 亚洲小视频在线| 久久国产精品久久w女人spa| 久久久久久电影| 美女免费视频一区| 亚洲激情一区| 亚洲精品九九| 亚洲淫片在线视频| 久久免费高清| 欧美视频一区二区三区四区| 国产日韩欧美| 亚洲精品在线二区| 午夜精品久久久久久久久| 久久久久久夜| 亚洲精选91| 久久国产加勒比精品无码| 欧美电影免费观看大全| 国产精品推荐精品| 亚洲日本电影| 久久久久久久国产| 一区二区国产在线观看| 久久综合99re88久久爱| 国产精品成人在线| 国产日韩一区二区三区| 乱码第一页成人| 在线视频日韩精品| 久久亚洲图片| 亚洲狼人综合| 久久久久久久999| 国产精品免费久久久久久| 91久久极品少妇xxxxⅹ软件| 欧美一级午夜免费电影| 亚洲国产精品一区二区尤物区| 亚洲午夜精品在线| 欧美日韩1区| 在线精品亚洲| 久久精品人人做人人爽电影蜜月 | 国产偷国产偷精品高清尤物| aa国产精品| 亚洲国产成人91精品| 久久av在线| 国产日韩欧美在线播放| 亚洲欧美日韩一区二区在线| 日韩亚洲欧美在线观看| 欧美精品激情在线| 亚洲黄网站黄| 欧美成在线观看| 久久中文久久字幕| 亚洲成人在线观看视频| 久久午夜视频| 久久激情五月丁香伊人| 国产亚洲一区二区精品| 久久久91精品国产一区二区三区| 午夜久久一区| 国产亚洲精品久久久久婷婷瑜伽| 欧美一区二区三区免费观看| 亚洲女性裸体视频| 国产色综合网| 免费高清在线一区| 欧美成人激情在线| 一本色道久久88综合亚洲精品ⅰ | 国产精品久久久久久久久久ktv| 亚洲乱码一区二区| 亚洲美女色禁图| 国产精品高潮在线| 欧美一区免费视频| 久久av一区| 国内久久婷婷综合| 欧美成人综合在线| 欧美精品一区二| 亚洲欧美日韩爽爽影院| 亚洲欧美日韩高清| 一区视频在线| 亚洲精品1区2区| 国产精品人人做人人爽人人添| 久久精品国产欧美激情| 另类天堂av| 亚洲一区二区三区精品在线观看| 亚洲欧美日韩精品| 国产综合视频在线观看| 亚洲成色最大综合在线| 久久视频一区| 99精品欧美一区二区三区| 9l国产精品久久久久麻豆| 国产精一区二区三区| 欧美成人午夜视频| 国产精品白丝jk黑袜喷水| 久久久久久久一区| 欧美精品导航| 久久精品电影| 欧美精品三级日韩久久| 欧美一区二区在线视频| 玖玖玖免费嫩草在线影院一区| 中文亚洲字幕| 久久亚洲综合网| 欧美亚洲免费| 欧美国产第一页| 久久久精品国产免大香伊| 欧美日韩福利视频| 免费人成精品欧美精品| 国产精品影音先锋| 亚洲毛片在线看| 1204国产成人精品视频| 亚洲永久免费av| 一道本一区二区| 久久综合给合久久狠狠狠97色69| 午夜精品成人在线| 欧美日韩国产经典色站一区二区三区| 久久综合九色综合久99| 国产精品久久久久久久9999| 91久久久精品| 91久久夜色精品国产网站| 欧美一二三区精品| 性感少妇一区| 欧美亚洲不卡| 一本色道久久综合亚洲精品按摩| 亚洲黄色视屏| 免费的成人av| 欧美大香线蕉线伊人久久国产精品| 国产精品一区二区男女羞羞无遮挡 | 欧美激情1区2区3区| 影音先锋久久精品| 久久国产黑丝| 久久一综合视频| 国产一区二区高清不卡| 午夜精品在线观看| 久久成人av少妇免费| 国产欧美精品国产国产专区| 亚洲欧美成人网| 欧美中文字幕不卡| 国产性猛交xxxx免费看久久| 亚洲欧美视频在线观看| 欧美一区国产二区| 国产一区亚洲| 久久这里只精品最新地址| 欧美高清一区| 日韩亚洲一区在线播放| 欧美日韩国产欧| 在线中文字幕日韩| 欧美一区视频在线| 国内一区二区三区| 美日韩精品免费| 亚洲国产天堂久久国产91| 在线观看欧美视频| 欧美日韩亚洲综合| 免费成人网www| 91久久精品日日躁夜夜躁国产| 老色批av在线精品| 亚洲国产日本| 亚洲视频免费观看| 国产欧美一区二区三区久久人妖| 欧美一级二区| 亚洲缚视频在线观看| 亚洲视频在线二区| 国产免费亚洲高清| 免费看精品久久片| 宅男噜噜噜66国产日韩在线观看| 欧美亚洲在线观看| 亚洲第一精品电影| 国产精品v日韩精品| 欧美专区中文字幕| 亚洲精品小视频| 久久久久国产精品午夜一区| 最新高清无码专区| 欧美午夜无遮挡| 久久夜色精品国产欧美乱| 日韩亚洲在线观看| 久久久人成影片一区二区三区观看| 亚洲日本欧美日韩高观看| 欧美日韩免费在线观看| 久久九九免费视频| 一本色道久久88综合亚洲精品ⅰ| 久久久久久久一区二区| 一区二区日韩免费看| 红桃视频成人| 国产精品女人毛片| 欧美高清一区| 久久激情五月婷婷| 亚洲视频中文字幕| 亚洲国产精品第一区二区三区| 欧美在线地址| 亚洲一级黄色片| 亚洲精品欧美专区| 一区二区三区中文在线观看| 国产精品久久久久一区| 欧美精品一区二区三区高清aⅴ| 欧美一区二区三区四区夜夜大片| 亚洲最新合集| 亚洲国产欧美另类丝袜| 美玉足脚交一区二区三区图片| 小处雏高清一区二区三区| 一区二区三区欧美在线观看| 亚洲人成网在线播放| 在线欧美亚洲|