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

            Feedback

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

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

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

            久久99精品久久久久久齐齐| 精品久久久一二三区| a级成人毛片久久| 国产精品女同一区二区久久| 99久久99久久精品国产| 性做久久久久久免费观看| 亚洲AV无码久久精品蜜桃| 久久亚洲国产精品一区二区| 亚洲国产成人久久综合区| av无码久久久久久不卡网站| 久久精品国产亚洲Aⅴ蜜臀色欲| 久久人人爽人人爽人人av东京热| 国产精品久久久久aaaa| 久久综合狠狠综合久久97色| 狠狠综合久久综合88亚洲| 狠狠色婷婷综合天天久久丁香| 亚洲国产成人久久综合一区77| 婷婷五月深深久久精品| 精品无码人妻久久久久久| 亚洲午夜久久久久久久久电影网 | 亚洲婷婷国产精品电影人久久| 亚洲AV无码1区2区久久| 久久婷婷人人澡人人| 久久亚洲国产中v天仙www| 国产亚洲美女精品久久久2020| 欧美日韩中文字幕久久久不卡| 狠狠久久亚洲欧美专区| 精品国产VA久久久久久久冰| 久久成人国产精品免费软件| 久久中文精品无码中文字幕| 国产一区二区精品久久凹凸| 2020久久精品国产免费| 久久久久国产精品熟女影院| 欧美亚洲国产精品久久| 亚洲日本久久久午夜精品| 99久久精品九九亚洲精品| 久久久久夜夜夜精品国产| 99国产欧美精品久久久蜜芽| 精品久久久噜噜噜久久久| 精品久久久久久久无码| 久久这里只有精品18|