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

            sherrylso

            C++博客 首頁 新隨筆 聯系 聚合 管理
              18 Posts :: 0 Stories :: 124 Comments :: 0 Trackbacks

                   Windows Nativec++應用大量使用了DLL技術。"動態鏈接"這幾字指明了DLLs是如何工作的。對于常規的函數庫,鏈接器從中拷貝它需要的所有庫函數,并把確切的函數地址傳送給調用這些函數的程序。而對于DLLs,函數儲存在一個獨立的動態鏈接庫文件中。在創建Windows程序時,鏈接過程并不把DLLs文件鏈接到程序上。直到程 序運行并調用一個DLLs中的函數時,該程序才要求這個函數的地址。此時Windows才在DLLs中尋找被調用函數,并把它的地址傳送給調用程序。采用這種方法,DLLs達到了復用代碼的極限。

                  對于DLL, 關鍵一點是,所有run on windows system 的程序可以共用同一個DLL庫,從而達到最大限度的代碼復用。并且,由于DLL并不拷貝它需要的所有庫函數 , 這樣的話NativeC++程序 executable image size 會比較小。

                  modularity的角度,如果要在Java的應用里尋找相對應的DLL的概念,我們會自然地想到jar包。JAR包可以被 Class Loader動態裝載進JVM, 不過要幾點區別需要說明的是:

            第一、從本質上來講,JAR包是存在于磁盤上的一些data而已(JVM解釋執行),而DLLexecutable image。

            第二、Class Data Sharing (CDS)作為一個新的feature,Java5才被引入,其做法就是:把 system jar 文件打包成為"shared archive",這些"shared archive"會作為memory-mapped in文件存在,共享于不同的JVM 進程間,以減少JVMfootprint,加快Java應用的啟動時間。

                        值得一提的是:兩者都有所謂的HELL問題(JAR HELL vs DLL HELL),新老版本的兼容問題始終讓人頭疼。

            詳見解釋:

            http://en.wikipedia.org/wiki/DLL_hell

            http://en.wikipedia.org/wiki/JAR_hell#JAR_hell

                


            posted on 2009-02-18 15:28 愛上龍卷風 閱讀(2594) 評論(2)  編輯 收藏 引用

            Feedback

            # re: 程序的模塊化之:關于Native DLL和Java JAR的一些思考 2009-02-18 17:46 路人乙
            是翻譯的文章嗎,怎么有些地方讀著不順不清不楚的?
            比如“對于常規的函數庫,鏈接器從中拷貝它需要的所有庫函數,并把確切的函數地址傳送給調用這些函數的程序。”
            “常規的函數庫”此處確切的指普通靜態庫,而不是“常規”的意思,“連接器從中”是指“從”靜態庫“中”,“函數地址傳送”其實本質上講編譯器做的并不是“傳送”動作,而是將二進制代碼從定位后的相對地址填入函數調用處。

            后面就更多了,尤其那些中英文夾雜的地方莫名其妙的保留英文原文,那些都是有明確的中文表達方式的,不是什么非英文描述不可的概念。  回復  更多評論
              

            # re: 程序的模塊化之:關于Native DLL和Java JAR的一些思考 2009-02-18 18:02 愛上龍卷風
            @路人乙
            多謝!  回復  更多評論
              

            美女久久久久久| 国内精品久久久人妻中文字幕| 99久久成人18免费网站| 久久久久久久综合综合狠狠| 99精品国产综合久久久久五月天 | 性做久久久久久久| 国产亚洲欧美成人久久片| 亚洲精品99久久久久中文字幕| 无码人妻久久一区二区三区 | 色综合久久最新中文字幕| 久久丫忘忧草产品| 久久93精品国产91久久综合| 亚洲va国产va天堂va久久| 欧美午夜A∨大片久久 | 国产精品99久久精品| 久久久亚洲欧洲日产国码是AV| 精品99久久aaa一级毛片| 国产午夜免费高清久久影院| 怡红院日本一道日本久久 | 无码AV波多野结衣久久| 色播久久人人爽人人爽人人片aV| 国产精品久久亚洲不卡动漫| 人妻精品久久久久中文字幕69| 久久精品中文字幕一区| 久久国产精品免费一区| 99久久精品免费国产大片| 久久久久免费精品国产| 国产产无码乱码精品久久鸭| 亚洲欧美日韩中文久久| 777午夜精品久久av蜜臀| 伊人久久大香线焦AV综合影院| 无码精品久久一区二区三区| 久久久精品国产亚洲成人满18免费网站 | 久久精品国产亚洲av瑜伽| 精品久久久久国产免费 | 久久婷婷五月综合国产尤物app| 久久这里有精品| 亚洲精品无码久久久久久| 久久亚洲精精品中文字幕| 99国产欧美久久久精品蜜芽| 国产精品久久久久9999高清|