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

牽著老婆滿街逛

嚴以律己,寬以待人. 三思而后行.
GMail/GTalk: yanglinbo#google.com;
MSN/Email: tx7do#yahoo.com.cn;
QQ: 3 0 3 3 9 6 9 2 0 .

C++虛指針實現(xiàn)及效率

轉(zhuǎn)載自:http://blog.chinaunix.net/space.php?uid=22257012&do=blog&id=2655107

  1. 單繼承虛函數(shù)例子

    class Point {
    public:
    virtual ~Point();

    virtual Point& mult( float ) = 0;
    //  other operations 

    float x() const return _x; }
    virtual float y() const return 0; }
    virtual float z() const return 0; }
    // 

    protected:
    Point( 
    float x = 0.0 );
    float _x;
    }
    ;
    class Point2d : public Point {
    public:
    Point2d( 
    float x = 0.0float y = 0.0 )
    : Point( x ), _y( y ) 
    {}
    ~Point2d();

    // overridden base class virtual functions
    Point2d& mult( float );
    float y() const return _y; }

    //  other operations 

    protected:
    float _y;
    }
    ;
    class Point3d: public Point2d {
    public:
    Point3d( 
    float x = 0.0,
    float y = 0.0float z = 0.0 )
    : Point2d( x, y ), _z( z ) 
    {}
    ~Point3d();

    // overridden base class virtual functions
    Point3d& mult( float );
    float z() const return _z; }

    //  other operations 
    protected:
    float _z;
    }
    ;

    1. VtableVPTR結(jié)構(gòu)

    虛函數(shù)的實現(xiàn)是通過VTablevptr。每一個帶有虛函數(shù)的都有一個VTable,在編譯器生成,每一個帶有虛函數(shù)的類實例都有一個vptr,該類實例vptr指向該類的VTable,在運行期生成。


    如圖左部的類實例內(nèi)存結(jié)構(gòu),編譯器為之生成__vptr__Point的指針,指向該類的VTable

    VTable的結(jié)構(gòu)是一個函數(shù)指針數(shù)組,數(shù)組的每個元素是一個函數(shù)指針,指向該類虛函數(shù)的地址。因為基類PointPoint::mult()為純虛函數(shù),因此Point對應的mult函數(shù)指針指向一個pure_virtual_called(),拋出調(diào)用純虛函數(shù)錯誤。


    如圖VTable所示,Point類和其子類的析構(gòu)函數(shù)均在VTable[1]multVTable[2]yVTable[3]zVTable[4]。如果Point2d增加Point2d自己的虛函數(shù),同時Point3d繼承Point2d的虛函數(shù),他們相同的虛函數(shù)接口同樣對應于相同的VTable數(shù)組下標,如VTable[5],此由編譯器保證,因而編譯器對于虛函數(shù)接口能將其轉(zhuǎn)換為函數(shù)指針數(shù)組的下標。


    故,當調(diào)用

    ptr->z();

    編譯器實際調(diào)用的是:

    ( *ptr->vptr[ 4 ] )( ptr );

    從而可以找到ptr實際指向的VTable中的虛函數(shù)調(diào)用地址。


    1. 虛函數(shù)系統(tǒng)開銷

    為了實現(xiàn)虛函數(shù),編譯器產(chǎn)生的操作包括:

      1. 編譯期,為每一個類增加一個VTable函數(shù)指針數(shù)組,并使其指向正確的虛函數(shù)實現(xiàn)。

      2. 運行期,在類的構(gòu)造函數(shù)中,為每一個類實例增加一個vptr,指向該類的VTable

      3. 編譯器,將虛函數(shù)調(diào)用編譯為函數(shù)指針的調(diào)用。

      4. 運行期,在虛函數(shù)調(diào)用時,通過指向VTable和調(diào)用函數(shù)的index,查找函數(shù)指針(查找效率為數(shù)組隨機訪問,常數(shù)時間),調(diào)用虛函數(shù)。


    由分析得,虛函數(shù)開銷主要在編譯期的VTable函數(shù)指針數(shù)組的構(gòu)造,而運行期的函數(shù)指針查找不是性能瓶頸。同時,一個帶虛函數(shù)的基類無論有多少個孩子類,并不會降低虛函數(shù)性能,而如果類的繼承層次太深,底層類實例的構(gòu)造函數(shù)則需要為類繼承層次的每一層父類初始化vptr,效率降低。


    1. 虛函數(shù)系統(tǒng)性能測試

      void
      cross_product( 
      const pt3d &pA, const pt3d &pB )
      {
      pt3d pC;

      pC.x 
      = pA.y * pB.z - pA.z * pB.y;
      pC.y 
      = pA.z * pB.x - pA.x * pB.z;
      pC.z 
      = pA.x * pB.y - pA.y * pB.x;
      }

      main() 
      {
      pt3d pA( 
      1.7250.8750.478 );
      pt3d pB( 
      0.3150.3170.838 );

      for ( int iters = 0; iters < 10000000; iters++ )
      cross_product( pA, pB );

      return 0;
      }

    Optimized Non-optimized

    Inline Member 0.08 4.70

    Nonstatic Member 4.43 6.13

    Virtual Member

    CC 4.76 6.90

    NCC 4.63 7.72

    CCNCC是比較的兩個編譯器版本,對于上述計算函數(shù)的測試,虛函數(shù)的調(diào)用開銷主要是3.4虛表查詢,虛函數(shù)調(diào)用損失了4% 11%的運行時間。相對于IO操作,可以忽略。


     

    1. 參考文獻

    Inside the C++ Object Model, By Stanley B. Lippman


posted on 2011-10-24 16:00 楊粼波 閱讀(1363) 評論(0)  編輯 收藏 引用 所屬分類: C++

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲国产三级网| 在线观看一区二区精品视频| 一区二区国产精品| 亚洲精品国产精品国自产在线 | 久久久久久综合| 在线看片日韩| 亚洲二区在线| 亚洲高清毛片| 久久精品亚洲一区二区| 在线看日韩av| 亚洲日韩中文字幕在线播放| 欧美性做爰毛片| 久久国产精品第一页| 久久嫩草精品久久久精品一| 亚洲日本成人在线观看| 亚洲先锋成人| 伊人激情综合| 一区二区三区日韩| 韩国成人福利片在线播放| 亚洲国产91精品在线观看| 国产精品va在线播放| 久久在线视频| 欧美日韩精品在线播放| 久久精品亚洲一区| 欧美另类99xxxxx| 久久国产夜色精品鲁鲁99| 欧美xxxx在线观看| 久久精品国产在热久久 | 亚洲福利免费| 国产精品亚洲а∨天堂免在线| 久久综合国产精品台湾中文娱乐网| 欧美日本在线观看| 老司机成人网| 国产精品丝袜白浆摸在线| 欧美黄色成人网| 国产日产欧美一区| 亚洲乱码视频| 在线观看视频免费一区二区三区| 一级日韩一区在线观看| 亚洲国产高清aⅴ视频| 亚洲欧美国产高清| 亚洲五月六月| 欧美成人免费全部| 欧美va亚洲va香蕉在线| 国产婷婷97碰碰久久人人蜜臀| 亚洲精品色婷婷福利天堂| 在线免费观看视频一区| 小处雏高清一区二区三区| 亚洲欧美成人网| 欧美精品在线一区二区| 欧美xxxx在线观看| 精品成人一区二区三区四区| 亚洲欧美国产毛片在线| 亚洲免费中文| 国产精品女人网站| 中国成人亚色综合网站| 国产精品99久久99久久久二8 | 亚洲欧美日韩精品久久亚洲区| 欧美看片网站| 亚洲卡通欧美制服中文| 夜夜精品视频| 欧美日韩一二三区| 亚洲蜜桃精久久久久久久| 亚洲最新在线视频| 欧美日韩极品在线观看一区| 亚洲精品久久久久久一区二区 | 久久久久久亚洲综合影院红桃| 欧美一区二区三区视频在线观看 | 久久国产主播| 久热国产精品| 1024国产精品| 欧美电影免费观看网站| 亚洲精品中文字幕女同| 一区二区三区高清不卡| 欧美日韩综合不卡| 亚洲夜间福利| 久久精品日产第一区二区| 国产亚洲欧洲| 老司机一区二区| 最新日韩中文字幕| 亚洲女同性videos| 国产欧美日韩专区发布| 久久久久久久激情视频| 亚洲国产另类精品专区 | 国产精品三上| 久久视频国产精品免费视频在线| 亚洲第一在线视频| 亚洲一级二级在线| 国产一区二区精品久久99| 久久一本综合频道| 国产精品99久久不卡二区 | 亚洲欧洲日产国码二区| 国产精品久久久免费| 久久精品成人欧美大片古装| 最新日韩中文字幕| 欧美亚洲在线| 亚洲精品1区| 国产精品日日摸夜夜摸av| 欧美一区二区三区日韩| 亚洲国产精品t66y| 亚洲欧美99| 亚洲黄色在线| 国产精品视区| 欧美—级高清免费播放| 欧美亚洲一区| 99精品视频免费| 免费不卡亚洲欧美| 亚洲欧美国内爽妇网| 91久久午夜| 国产日韩综合| 欧美日韩大片| 久久人人97超碰国产公开结果| 一本色道久久99精品综合| 免费久久久一本精品久久区| 午夜精品久久久久久久99热浪潮 | 亚洲一区二区三区777| ●精品国产综合乱码久久久久| 国产精品mm| 欧美另类视频在线| 久久网站热最新地址| 午夜精品视频网站| 一区二区日韩欧美| 亚洲精品1区| 女主播福利一区| 久久久精品性| 久久高清福利视频| 午夜伦欧美伦电影理论片| 一区二区高清视频| 日韩午夜电影| 亚洲精品在线观| 1769国产精品| 在线成人国产| 1024精品一区二区三区| 精品9999| 欧美激情亚洲另类| 噜噜噜在线观看免费视频日韩| 久久国产综合精品| 久久精品成人欧美大片古装| 香蕉成人久久| 欧美一区二区三区免费大片| 午夜一区二区三区不卡视频| 亚洲免费一区二区| 亚洲欧美另类综合偷拍| 午夜视频久久久| 欧美中文字幕视频| 久久精品国产精品亚洲| 久久久一区二区| 免费欧美电影| 欧美激情在线有限公司| 欧美精品一区二区在线播放| 欧美精品色网| 国产精品成人久久久久| 国产精品日韩欧美一区| 国产亚洲欧美一区| 激情久久一区| 亚洲精品日韩一| 亚洲深夜福利在线| 午夜天堂精品久久久久| 久久av资源网| 欧美大秀在线观看 | 欧美一区二区三区四区高清| 久久免费国产精品| 欧美黑人一区二区三区| 一本色道久久99精品综合| 午夜精品区一区二区三| 久久综合五月| 欧美日韩一区二区三区视频| 国产精品国产a| 黄色日韩精品| 亚洲视频精选| 久久精品综合一区| 亚洲国产精品美女| 亚洲综合国产激情另类一区| 久久国产福利| 欧美日韩视频在线一区二区| 国产欧美一区二区三区久久| 91久久久久久久久| 性久久久久久久| 亚洲高清视频在线观看| 亚洲尤物影院| 欧美 日韩 国产在线| 国产精品资源| 亚洲每日在线| 久久久久成人精品免费播放动漫| 亚洲人成人99网站| 久久精品国产一区二区三区| 欧美三级视频在线播放| 1769国产精品| 欧美在线视频全部完| 亚洲日产国产精品| 久久精品一本| 国产精品一区二区在线观看网站| 亚洲国产精品久久久久久女王| 午夜一区不卡| 99精品欧美一区| 欧美激情第9页| 激情久久久久| 久久精品卡一| 亚洲一区二区在线免费观看| 欧美黄色aa电影|