Linux下靜態(tài)庫和動態(tài)庫(共享庫)的制作與使用
Linux操作系統支持的函數庫分為靜態(tài)庫和動態(tài)庫,動態(tài)庫又稱共享庫。linux系統有幾個重要的目錄存放相應的函數庫,如/lib /usr/lib。
靜態(tài)函數庫:
這類庫的名字一般是libxxx.a;利用靜態(tài)函數庫編譯成的文件比較大,因為整個函數庫的所有數據都會被整合進目標代碼中,他的優(yōu)點就顯而易見了,即編譯后的執(zhí)行程序不需要外部的函數庫支持,因為所有使用的函數都已經被編譯進可執(zhí)行文件了。當然這也會成為他的缺點,因為如果靜態(tài)函數庫改變了,那么你的程序必須重新編譯,而且體積也較大。
動態(tài)函數庫:
這類庫的名字一般是libxxx.so,動態(tài)庫又稱共享庫;相對于靜態(tài)函數庫,動態(tài)函數庫在編譯的時候并沒有被編譯進目標代碼中,你的程序執(zhí)行到相關函數時才調用該函數庫里的相應函數,因此動態(tài)函數庫所產生的可執(zhí)行文件比較小。由于函數庫沒有被整合進你的程序,而是程序運行時動態(tài)的申請并調用,所以程序的運行環(huán)境中必須提供相應的庫。動態(tài)函數庫的改變并不影響你的程序,所以動態(tài)函數庫的升級比較方便。而且如果多個應用程序都要使用同一函數庫,動態(tài)庫就非常適合,可以減小應用程序的體積。
下面來介紹linux靜態(tài)函數庫的創(chuàng)建和使用:
例程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);
評論