Linux中如何創建靜態庫和動態庫

靜態庫在程序編譯時會被連接到目標代碼中,程序運行時將不再需要該靜態庫。

  動態庫在程序編譯時並不會被連接到目標代碼中,而是在程序運行是才被載入,因此在程序運行時還需要動態庫存在。

  程序1: hello.h

  #ifndef HELLO_H

  #define HELLO_H

  void hello(const char *name);

  #endif //HELLO_H

  程序2: hello.c

  #include <stdio.h>

  void hello(const char *name)

  {

  printf(“Hello %s!\n”, name);

  }

  程序3: main.c

  #include “hello.h”

  int main()

  {

  hello(“everyone”);

  return 0;

  }

  無論動態庫還是靜態庫都需要用到.o文件來生成,先編譯生成.o文件。

  # gcc -c hello.c

  1:創建靜態庫

  靜態庫文件名的命名規範是以lib為前綴,緊接著跟靜態庫名,擴展名為.a。例如:我們將創建的靜態庫名為myhello,則靜態庫文件名就是libmyhello.a。

  # ar cr libmyhello.a hello.o

  使用靜態庫:只需要在妳的源程序中加入包含妳所需要使用到的函數的聲明(即包含頭文件),然後在gcc生成目標文件時候指明靜態庫就OK了(除非妳包含的頭文件在/usr/include,庫文件在標準庫/usr/lib,/lib下,否則妳得顯示指明他們的路徑)

  # gcc -o hello main.c -L. -lmyhello

  # ./hello

  Hello everyone!

  刪除靜態庫文件運行./hello,程序正常運行,說明靜態庫公用函數已經鏈接到目標文件。

  2: 利用.o文件創建動態庫

  動態庫文件擴展名為.so。

  # gcc -shared -fPCI -o libmyhello.so hello.o

  動態庫的使用與靜態庫使用方式壹樣

  # gcc -o hello main.c -L. -lmyhello

  # ./hello

  ./hello: error while loading shared libraries: libmyhello.so: cannot open shared object file: No such file or directory

  哦!出錯了。快看看錯誤提示,原來是找不到動態庫文件libmyhello.so。程序在運行時,會在/usr/lib和/lib等目錄中查找需要的動態庫文件。若找到,則載入動態庫,否則將提示類似上述錯誤而終止程序運行。

  如何找到生成的動態庫有3種方式:

  1)把庫拷貝到/usr/lib和/lib目錄下。

  (2)在LD_LIBRARY_PATH環境變量中加上庫所在路徑。

  例如動態庫libhello.so在/home/example/lib目錄下:

  $export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/home/example/lib

  (3) 修改/etc/ld.so.conf文件,把庫所在的路徑加到文件末尾,並執行ldconfig刷新。這樣,加入的目錄下的所有庫文件都可見。

  當靜態庫和動態庫同名時, gcc命令將優先使用動態庫。

  函數庫分為靜態庫和動態庫兩種。

  靜態庫在程序編譯時會被連接到目標代碼中,程序運行時將不再需要該靜態庫。

  動態庫在程序編譯時並不會被連接到目標代碼中,而是在程序運行是才被載入,因此在程序運行時還需要動態庫存在。

  程序1: hello.h

  #ifndef HELLO_H

  #define HELLO_H

  void hello(const char *name);

  #endif //HELLO_H

  程序2: hello.c

  #include <stdio.h>

  void hello(const char *name)

  {

  printf(“Hello %s!\n”, name);

  }

  程序3: main.c

  #include “hello.h”

  int main()

  {

  hello(“everyone”);

  return 0;

  }

  無論動態庫還是靜態庫都需要用到.o文件來生成,先編譯生成.o文件。

  # gcc -c hello.c

  1:創建靜態庫

  靜態庫文件名的命名規範是以lib為前綴,緊接著跟靜態庫名,擴展名為.a。例如:我們將創建的靜態庫名為myhello,則靜態庫文件名就是libmyhello.a。

  # ar cr libmyhello.a hello.o

  使用靜態庫:只需要在妳的源程序中加入包含妳所需要使用到的函數的聲明(即包含頭文件),然後在gcc生成目標文件時候指明靜態庫就OK了(除非妳包含的頭文件在/usr/include,庫文件在標準庫/usr/lib,/lib下,否則妳得顯示指明他們的路徑)

  # gcc -o hello main.c -L. -lmyhello

  # ./hello

  Hello everyone!

  刪除靜態庫文件運行./hello,程序正常運行,說明靜態庫公用函數已經鏈接到目標文件。

  2: 利用.o文件創建動態庫

  動態庫文件擴展名為.so。

  # gcc -shared -fPCI -o libmyhello.so hello.o

  動態庫的使用與靜態庫使用方式壹樣

  # gcc -o hello main.c -L. -lmyhello

  # ./hello

  ./hello: error while loading shared libraries: libmyhello.so: cannot open shared object file: No such file or directory

  哦!出錯了。快看看錯誤提示,原來是找不到動態庫文件libmyhello.so。程序在運行時,會在/usr/lib和/lib等目錄中查找需要的動態庫文件。若找到,則載入動態庫,否則將提示類似上述錯誤而終止程序運行。

  如何找到生成的動態庫有3種方式:

  1)把庫拷貝到/usr/lib和/lib目錄下。

  (2)在LD_LIBRARY_PATH環境變量中加上庫所在路徑。

  例如動態庫libhello.so在/home/example/lib目錄下:

  $export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/home/example/lib

  (3) 修改/etc/ld.so.conf文件,把庫所在的路徑加到文件末尾,並執行ldconfig刷新。這樣,加入的目錄下的所有庫文件都可見。

  當靜態庫和動態庫同名時, gcc命令將優先使用動態庫。