通常我們所說的靜態鏈接庫就是.lib文件,文件一般比較大,能夠將函數和數據編譯到一個.lib文件中,那麼Linux系統要如何建立靜態鏈接庫呢?下面小編就給大家介紹下Linux建立靜態鏈接庫的方法。
主要有兩步:
1.編譯源碼
2.制作庫
=====================================
以兩個簡單的源碼為例,示范靜態庫制作的具體流程
1.編譯源碼
hello_first.c
void hello_first(void)
{
printf(“hello first”);
}
hello_second.c
void hello_second(void)
{
printf(“hello second”);
}
編譯:
gcc -c hello_first.c -o hello_first.o
gcc -c hello_second.c -o hello_second.o
2.制作靜態庫
ar -r libhello.a hello_first.o hello_second.o
具體調用庫實例
hello_main.c
#include 《stdio.h》
void hello_first(void);
void hello_second(void);
int main()
{
hello_first();
hello_second();
return 0;
}
編譯:
第一種方法:
gcc hello_main.c libhello.a -o hello_main
第二中方法:
拷貝libhello.a到/lib目錄下
gcc hello_main.c -lhello -o hello_main2
運行截圖:
OK!靜態庫調用成功!!
思考:
靜態庫作用是什麼?為甚麼要發明它?
1.靜態庫主要是用於方便程序員編程,將要使用的函數封裝成庫,只要告訴他們函數接口就可以了,這樣程序員只要知道怎麼調用就行了。而廠家可以保持接口不變,而對代碼進行修改維護。
2.另外有可能是程序員自己將自己經常用到的函數封裝起來,不用重復編寫,只需調用前聲明下就可以了。
上面就是Linux建立靜態鏈接庫的相關介紹了,在制作靜態鏈接庫的時候需要先編譯源碼,然後再制作靜態鏈接庫,制作好後需運行監測。