• <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>
            posts - 2, comments - 6, trackbacks - 0, articles - 0
              C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

            C++ 初始化函數(shù)的實現(xiàn)

            Posted on 2007-11-21 16:31 Ling Xu 閱讀(2711) 評論(2)  編輯 收藏 引用

            講一點(diǎn)和實現(xiàn)細(xì)節(jié)相關(guān)的東西。在Visual C++中,所有在main之前執(zhí)行的函數(shù)調(diào)用實際上都通過一個自動生成的函數(shù)來調(diào)用,比如下面這段代碼:

            int func()
            {
             return 1;
            }

            int data = func();

            int main()
            {
             return 0;
            }

            實際上生成了三個函數(shù):

            ?func@@YAHXZ,對應(yīng)于 func
            _main 對應(yīng)于 main
            _$E1 對應(yīng)于 data=func() 這句賦值語句。它調(diào)用了 func,并且完成賦值這個操作。

            竅門在于,VC將 _$E1這個函數(shù)的指針放到了段CRT$XCU中:

            CRT$XCU SEGMENT
            _$S2 DD FLAT:_$E1
            ; Function compile flags: /Odt /RTCsu /ZI
            CRT$XCU ENDS

            這個段的定義為:

            CRT$XCU SEGMENT DWORD USE32 PUBLIC 'DATA'
            CRT$XCU ENDS

            參考 crt0dat.c 文件可以看到:

            extern _CRTALLOC(".CRT$XIA") _PIFV __xi_a[];
            extern _CRTALLOC(".CRT$XIZ") _PIFV __xi_z[];    /* C initializers */
            extern _CRTALLOC(".CRT$XCA") _PVFV __xc_a[];
            extern _CRTALLOC(".CRT$XCZ") _PVFV __xc_z[];    /* C++ initializers */
            extern _CRTALLOC(".CRT$XPA") _PVFV __xp_a[];
            extern _CRTALLOC(".CRT$XPZ") _PVFV __xp_z[];    /* C pre-terminators */
            extern _CRTALLOC(".CRT$XTA") _PVFV __xt_a[];
            extern _CRTALLOC(".CRT$XTZ") _PVFV __xt_z[];    /* C terminators */

            這里實際上有一個很巧妙的地方在于,VC應(yīng)用了x86上段是連續(xù)并且可重疊的概念,因此CRT$XCU是位于CRT$XCA到CRT$XCZ之間,具體說,段的順序是:

            CRT$XCA SEGMENT DWORD USE32 PUBLIC 'DATA'
            CRT$XCA ENDS
            CRT$XCU SEGMENT DWORD USE32 PUBLIC 'DATA'
            CRT$XCU ENDS
            CRT$XCL SEGMENT DWORD USE32 PUBLIC 'DATA'
            CRT$XCL ENDS
            CRT$XCC SEGMENT DWORD USE32 PUBLIC 'DATA'
            CRT$XCC ENDS
            CRT$XCZ SEGMENT DWORD USE32 PUBLIC 'DATA'
            CRT$XCZ ENDS

            由于CRT$XCA開始都是C++初始化函數(shù),_PVFV實際上就是 void (*_PVFV)(),因此CRT的_initterm()函數(shù)就把這個段中的數(shù)據(jù)作為一個函數(shù)指針數(shù)組來訪問,依次調(diào)用其中的函數(shù),從而完成系統(tǒng)所有初始化操作。

            最后,也是最關(guān)鍵的問題,就是實際上每個 CPP 文件編譯好以后都有初始化函數(shù),并且其指針位于 CRT$XC? 段中,隨后連接程序 LINK 做了最后一個重要的任務(wù),就是把所有具有相同名字的段合并成為一個單獨(dú)的段(這也就是連接程序名字的由來之一),合并的做法就是簡單地把每個段中的數(shù)據(jù)按順序前后放到一個連續(xù)的空間就可以了。這樣在最終運(yùn)行的時候,程序看到的CRT$XC?段也就是一個連續(xù)的數(shù)組,而不是多個數(shù)組。

            至于順序問題,在這里就可以看到,是由連接程序最后做拼接時候確定的。連接程序拼接的順序,基本上是它看到OBJ文件的順序,也就是在連接程序命令行指定的順序。因此,在程序中決不能依賴于這個順序,因為在連接程序命令行中的文件順序是不確定的。

            以上是初始化程序的順序,至于析構(gòu)函數(shù)(或者在main函數(shù)之后的函數(shù)調(diào)用)則是通過用at_exit函數(shù)注冊的順序來確定,而注冊往往是在初始化的時候進(jìn)行,因此析構(gòu)函數(shù)的調(diào)用順序也是不確定的。

             


             

            Feedback

            # re: C++ 初始化函數(shù)的實現(xiàn)  回復(fù)  更多評論   

            2007-11-21 17:05 by
            因為沒有標(biāo)準(zhǔn)規(guī)定,所以就自由實現(xiàn)了,只需要保證在main之前能初始化就正確了

            # re: C++ 初始化函數(shù)的實現(xiàn)  回復(fù)  更多評論   

            2007-12-07 15:49 by vc
            好文

            只有注冊用戶登錄后才能發(fā)表評論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            久久精品国产亚洲Aⅴ香蕉| 伊人久久大香线蕉影院95| 亚洲国产精品久久久久网站| 精品久久久久久亚洲精品| 久久精品aⅴ无码中文字字幕不卡| 无码专区久久综合久中文字幕 | 久久久无码精品亚洲日韩按摩| 超级碰碰碰碰97久久久久| 亚洲AV无码久久精品成人| 大伊人青草狠狠久久| 狠狠色婷婷久久一区二区| 婷婷综合久久狠狠色99h| 久久久久久久免费视频| 国产激情久久久久影院小草| 亚洲国产精品无码久久| 国产亚洲精午夜久久久久久| 久久精品视频网| 久久免费视频观看| 久久国产美女免费观看精品| 狠狠色丁香婷婷综合久久来| 伊人久久无码中文字幕| 久久一日本道色综合久久| 久久午夜福利无码1000合集| 亚洲七七久久精品中文国产| 少妇被又大又粗又爽毛片久久黑人| 91精品国产色综久久| 草草久久久无码国产专区| 99久久精品免费| 日韩AV无码久久一区二区| 国内精品久久久人妻中文字幕| 精品999久久久久久中文字幕| 品成人欧美大片久久国产欧美...| Xx性欧美肥妇精品久久久久久| 亚洲国产天堂久久综合| 日产精品久久久久久久| 久久综合色之久久综合| …久久精品99久久香蕉国产| 久久人妻少妇嫩草AV无码蜜桃 | 中文字幕无码久久精品青草| 久久这里只有精品首页| 91麻精品国产91久久久久|