• <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 愛上龍卷風 閱讀(2575) 評論(2)  編輯 收藏 引用

            Feedback

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

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

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

            国产精品久久国产精麻豆99网站| 久久精品国产99久久无毒不卡| 青青青青久久精品国产h| 精品久久久久久久| 人人狠狠综合久久亚洲88| 久久国产热这里只有精品| 久久精品一区二区影院| 老司机午夜网站国内精品久久久久久久久 | 99久久www免费人成精品| 国产精品免费久久久久电影网| 久久99精品久久久久久9蜜桃| 亚洲国产精品无码久久久蜜芽| 久久亚洲国产午夜精品理论片| 中文成人久久久久影院免费观看| 久久人爽人人爽人人片AV| 国产ww久久久久久久久久| 久久99久国产麻精品66 | 欧美午夜A∨大片久久| 激情伊人五月天久久综合| 久久精品国产2020| 久久亚洲国产成人影院| 香港aa三级久久三级老师2021国产三级精品三级在 | 久久影院亚洲一区| 丁香久久婷婷国产午夜视频| 精品久久久久久中文字幕人妻最新| 香蕉久久AⅤ一区二区三区| 亚洲午夜久久久精品影院| 狠狠色丁香婷综合久久| 久久福利青草精品资源站免费| 久久国产精品77777| 久久99精品久久久久子伦| 精品久久久久久国产潘金莲| 国产精品免费福利久久| 一本大道久久a久久精品综合| 国内精品久久久久久久久电影网| 国产成人精品综合久久久| 久久久久久国产精品无码下载| 精品久久久一二三区| 久久精品中文无码资源站| 久久综合给合久久狠狠狠97色| 久久综合丁香激情久久|