• <li id="00i08"><input id="00i08"></input></li>
  • <sup id="00i08"><tbody id="00i08"></tbody></sup>
    <abbr id="00i08"></abbr>
  • 新聞中心

    EEPW首頁 > 嵌入式系統 > 設計應用 > Linux下靜態庫和動態庫(共享庫)的制作與使用

    Linux下靜態庫和動態庫(共享庫)的制作與使用

    作者: 時間:2010-12-13 來源:網絡 收藏

    操作系統支持的函數庫分為庫和庫,庫又稱庫。linux系統有幾個重要的目錄存放相應的函數庫,如/lib /usr/lib。

    函數庫:
      這類庫的名字一般是libxxx.a;利用函數庫編譯成的文件比較大,因為整個函數庫的所有數據都會被整合進目標代碼中,他的優點就顯而易見了,即編譯后的執行程序不需要外部的函數庫支持,因為所有的函數都已經被編譯進可執行文件了。當然這也會成為他的缺點,因為如果靜態函數庫改變了,那么你的程序必須重新編譯,而且體積也較大。

    函數庫:
      這類庫的名字一般是libxxx.so,動態庫又稱庫;相對于靜態函數庫,動態函數庫在編譯的時候并沒有被編譯進目標代碼中,你的程序執行到相關函數時才調用該函數庫里的相應函數,因此動態函數庫所產生的可執行文件比較小。由于函數庫沒有被整合進你的程序,而是程序運行時動態的申請并調用,所以程序的運行環境中必須提供相應的庫。動態函數庫的改變并不影響你的程序,所以動態函數庫的升級比較方便。而且如果多個應用程序都要同一函數庫,動態庫就非常適合,可以減小應用程序的體積。

    下面來介紹linux靜態函數庫的創建和

      例程add.h add.c sub.h
    sub.c
    main.c:


      add.h

      #ifndef ADD_H
      #define ADD_H
      int add(int x,int y);
      #endif

      add.c

      #include stdio.h>
      #include add.h

    int add(int x,int y)
    {
      
    return (x+y);

    }
    --------------------------------------------------------------------

    sub.h


      #ifndef SUB_H
      #define SUB_H
      int sub(int x,int y);
      #endif

      sub.c

      #include stdio.h>
      #include sub.h
    int sub(int x,int y)
    {
      
    return (x-y);

      }
    -----------------------------------------------------------------------
    main.c

    #include stdio.h>
      #include sub.h
    #include add.h

      int main()
    {

    int
    a,b;


    a = add(1,2);


    b = sub(10,5);

    linux操作系統文章專題:linux操作系統詳解(linux不再難懂)

    上一頁 1 2 下一頁

    評論


    相關推薦

    技術專區

    關閉
    主站蜘蛛池模板: 攀枝花市| 宜都市| 绩溪县| 东乡族自治县| 民县| 鄂托克旗| 余庆县| 桦南县| 凯里市| 大同市| 舞钢市| 昭平县| 文成县| 武强县| 蒙自县| 钦州市| 扬州市| 刚察县| 东丰县| 枝江市| 广德县| 绵阳市| 静宁县| 武宁县| 安化县| 灌阳县| 桐乡市| 称多县| 随州市| 固始县| 深水埗区| 武宁县| 白山市| 宁夏| 静乐县| 三门峡市| 铜川市| 桐梓县| 神木县| 乌拉特后旗| 渑池县|