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

            Prayer

            在一般中尋求卓越
            posts - 1256, comments - 190, trackbacks - 0, articles - 0
              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

            http://www.shnenglu.com/wolf/articles/74928.html

            http://www.shnenglu.com/wolf/articles/77828.html

            http://www.jb51.net/article/34990.htm

            1.概念和區別:
                靜態庫就是在編譯過程中一些目標文件的集合。靜態庫在程序鏈接的時候使用,鏈接器會將程序中使用到函數的代碼從庫文件中拷貝到應用程序中。一旦鏈接完成,在執行程序的時候就不需要靜態庫了。 
                由于每個使用靜態庫的應用程序都需要拷貝所用函數的代碼,所以靜態鏈接的文件會比較大。

                相對于靜態函數庫,動態函數庫在編譯的時候并沒有被編譯進目標代碼中,而只是作些標記。然后在程序開始啟動運行的時候,動態地加載所需模塊,因此動態函數庫所產生的可執行文件比較小。由于函數庫沒有被整合進你的程序,而是程序運行時動態的申請并調用,所以程序的運行環境中必須提供相應的庫。動態函數庫的改變并不影響你的程序,所以動態函數庫的升級比較方便。

            2.命名:
                靜態庫的名字一般為libxxxx.a,其中xxxx是該lib的名稱。
                動態庫的名字一般為libxxxx.so.major.minor,xxxx是該lib的名稱,major是主版本號,minor是副版本號。版本號也可以沒有,一般都會建立個沒有版本號的軟連接文件鏈接到全名的庫文件。

            3.創建:
            無論靜態庫還是動態庫,創建都分為兩步,第一步創建目標文件,第二步生產庫。
            1).靜態庫的創建:
            #gcc -c test.c -o test.o
            #ar rcs libtest.a test.o
            名字為libtest.a的靜態庫就生產了,其中選項:
            r 表明將模塊加入到靜態庫中;
            c 表示創建靜態庫;
            s 表示生產索引;
            還有更多選項像增加、刪除庫中的目標文件,包括將靜態庫解包等可以通過man來獲得。
            2).動態庫的創建:
            #gcc -fPIC -c test.c -o test.c
            #gcc --share test.o -o libtest.so
            -fPIC 為了跨平臺

            4.使用:
            編譯鏈接目標程序的方法是一樣的:
            #gcc main.c -L. -ltest -o main
            -L.指定現在本目錄下搜索庫,如果沒有,會到系統默認的目錄下搜索,一般為/lib、/usr/lib下。
            對于靜態庫,這個步驟之后就可以將libtest.a庫刪掉,因為它已經被編譯進了目標程序,不再需要它了。
            而對于動態庫,libtest.so庫只是在目標程序里做了標記,在運行程序時才會動態加載,那么從哪加載呢?加載目錄會由/etc/ld.so.conf來指定,一般默認是/lib、/usr/lib,所以要想讓動態庫順利加載,你可以將庫文件copy到上面的兩個目錄下,或者設置export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/XXX/YYY,后面為你自己動態庫的目錄,再或者修改/etc/ld.so.conf文件,把庫所在的路徑加到文件末尾,并執行ldconfig刷新。這樣,加入的目錄下的所有庫文件都可見。

            另外還有個文件需要了解/etc/ld.so.cache,里面保存了常用的動態函數庫,且會先把他們加載到內存中,因為內存的訪問速度遠遠大于硬盤的訪問速度,這樣可以提高軟件加載動態函數庫的速度了。

            最后提一點,當同一目錄下既有動態庫又有靜態庫,并且兩個庫的名字相同時,編譯時會如何鏈接呢?

            gcc編譯時默認都是動態鏈接,如果要指定優先鏈接靜態庫,需要指定參數static。



            靜態庫

            1、命令gcc -c a.c b.c生成a.o和b.o;

            2、命令ar -r libname.a a.o b.o生成包含名為libname.a的靜態庫;

            3、命令gcc main.c libname.a可以在main中鏈接靜態庫libname.a。

            動態庫(共享庫)

            1、命令gcc -c a.c b.c生成a.o和b.o;

            2、命令gcc -shared libname.so a.o b.o生成包含名為libname.so的共享庫;

            3、命令gcc main.c libname.so可以在main中鏈接動態庫libname.a。與靜態庫不同,如果共享庫(.so)文件被刪除或被移動了,應用程序啟動時會出錯。

            硬鏈接(hard link)

            命令ln sourse dest可以為文件source創建一個名為dest的硬鏈接。兩個文件指向同一塊數據塊,所以對任意文件修改都會反映到其它所有被鏈接的文件上。如果source被刪除了,dest仍然有效,可以被使用。

            軟鏈接(symbolic link)

            命令ln -s source dest可以為文件source創建一個名為dest的軟鏈接。軟鏈接類似于Windows上的快捷方式。一旦source不存在了,那么dest的文件也會失效。

            使用系統庫

            通過硬鏈接的方式,可以把靜態庫和動態庫放到/usr/lib目錄下,這樣可以簡化gcc的編譯命令。

            1、命令ln libname.a /usr/lib/或ln libname.so /usr/lib/把庫文件libname.a或libname.so鏈接到/usr/lib下;

            2、命令gcc main.c -lname等同于gcc main.c /usr/lib/libname.so或gcc main.c /usr/lib/libname.so。

            同樣可以把庫文件鏈接到/lib目錄下并使用-l前綴來指定引用的庫。/usr/local/lib里的動態庫文件(*.so)在使用-l前綴引用時,可以通過編譯,但程序啟動時會出錯,靜態庫沒有問題



            伊人久久精品无码av一区| 国产精品青草久久久久福利99| 色婷婷久久久SWAG精品| 国内精品久久久久影院亚洲| 中文字幕久久精品 | 国产精品久久婷婷六月丁香| 伊人色综合久久天天人手人婷 | 99久久99久久久精品齐齐| 亚洲精品国产成人99久久| 久久99国产精品久久99小说| 久久A级毛片免费观看| 武侠古典久久婷婷狼人伊人| 精品综合久久久久久888蜜芽| 久久国产成人午夜aⅴ影院| 欧美噜噜久久久XXX| 亚洲美日韩Av中文字幕无码久久久妻妇 | 色综合久久天天综线观看| 久久99国产综合精品| 亚洲国产精品一区二区三区久久| AAA级久久久精品无码片| 国产aⅴ激情无码久久| 欧美性大战久久久久久| 麻豆精品久久精品色综合| 性色欲网站人妻丰满中文久久不卡 | 国产精品对白刺激久久久| 欧美精品国产综合久久| 久久国产精品无码网站| 久久亚洲综合色一区二区三区| 人妻无码中文久久久久专区| 偷窥少妇久久久久久久久| 久久久久国产精品嫩草影院| 国产成人精品久久综合| 国内精品伊人久久久久| 国产香蕉97碰碰久久人人| 天天躁日日躁狠狠久久| 国产成年无码久久久免费| 精品久久久久久久国产潘金莲| 麻豆国内精品久久久久久| 久久精品中文字幕有码| 久久久久国产一级毛片高清板 | 久久99热这里只有精品国产|