Ubuntu下makefile及gcc生成靜態庫動態庫的簡單使用舉例
環境:Ubuntu-13.10 32位(虛擬機)、gcc4.8.1
首先創建一個test_makefile_gcc文件夾,此test_makefile_gcc文件夾下包括:src文件夾用於存放源文件; include文件夾用於存放頭文件;bin文件夾用於存放生成的動態庫.so文件;lib文件夾用於存放生成的靜態庫.a文件;project_makefile文件夾存放此工程的makefile文件;test文件夾存放用來測試靜態庫和動態庫的源文件;另外在test_makefile_gcc文件夾下還包含一個makefile文件。
include文件夾下包括add.h、divide.h、hybrid.h、multiply.h、subtract.h:
add.h文件內容為:
int CalAdd(int a, int b);
divide.h文件內容為:
int CalDivide(int a, int b);
hybrid.h文件內容為:
int CalHybrid(int a, int b, int c, int d);
multiply.h文件內容為:
int CalMultiply(int a, int b);
subtract.h文件內容為:
int CalSubtract(int a, int b);
src文件夾下包括add.c、divide.cpp、hybrid.cpp、multiply.cpp、subtract.c:
add.c文件內容為:
#include "add.h"
int CalAdd(int a, int b)
{
return a + b;
}
divide.cpp文件內容為:
#include "divide.h"
int CalDivide(int a, int b)
{
return a / b;
}
hybrid.cpp文件內容為:
#include "hybrid.h"
extern "C" {
#include "add.h"
#include "subtract.h"
}
#include "multiply.h"
#include "divide.h"
int CalHybrid (int a, int b, int c, int d)
{
int tmp1=0, tmp2=0, tmp3=0, tmp4=0, result=0;
tmp1 = CalDivide(a, b);
tmp2 = CalMultiply(c, d);
tmp3 = CalAdd(tmp1, tmp2);
tmp4 = CalSubtract(tmp2, tmp1);
result = CalAdd(tmp3, tmp4);
return result;
}
multiply.cpp文件內容為:
#include "multiply.h"
int CalMultiply(int a, int b)
{
return a * b;
}
subtract.c文件內容為:
#include "subtract.h"
int CalSubtract(int a, int b)
{
return a - b;
}
project_makefile文件夾中makefile內容為:
add_cflags = -I../include
cxxsources = ../src/divide.cpp ../src/multiply.cpp ../src/hybrid.cpp
csources = ../src/add.c ../src/subtract.c
sources = $(cxxsources) $(csources)
include ../makefile
test_makefile_gcc文件夾中的makefile文件內容為:
debug: $(sources)
gcc -c -fPIC -ggdb $(add_cflags) $(sources)
release: $(sources)
gcc -c -Os -fPIC $(add_cflags) $(sources)
test文件夾中test_makefile_gcc.cpp文件的內容為:
#include "../include/hybrid.h"
#include <iostream>
using namespace std;
int main(int argc, char* argv[])
{
int a=10, b=200, c=-34, d=92;
int result = CalHybrid(a, b, c, d);
cout<<result<<endl;
return 0;
}
詳細操作步驟:
1、將終端定位到project_makefile文件夾下,執行命令: make debug ;在project_makefile文件夾下生成add.o、divide.o、hybrid.o、multiply.o、subtract.o文件;
2、在lib文件夾下生成靜態庫libtest[linux_dbg_32].a,執行命令:ar -r ../lib/libtest[linux_dbg_32].a *.o ;
3、將終端定位到test文件夾,執行命令:g++ -o test test_makefile_gcc.cpp -L ../lib -ltest[linux_dbg_32] ,生成test執行文件;
4、執行命令:./test ,輸出結果:-6256,Debug靜態庫的調用完成;
5、將終端重新定位到project_makefile文件夾下,執行命令:gcc -shared -o ../bin/libtest[linux_dbg_32].so *.o ,在bin文件夾下生成libtest[linux_dbg_32].so ;
6、執行命令:g++ -o ../test/test2 ../test/test_makefile_gcc.cpp -L ../bin -ltest[linux_dbg_32] ,在test文件夾下生成test2執行文件;
7、執行命令:export LD_LIBRARY_PATH=/home/spring/test_makefile_gcc/bin ,用於指定文件需調用的動態庫的路徑 (註:個人Ubuntu操作系統上實際的存放路徑);
8、執行命令:./test2 ,輸出結果:-6256,Debug動態庫的調用完成;
9、若生成Release的動態庫或靜態庫,執行 make release,其它步驟僅需修改生成的文件名即可。
Execute in turn:
$ mkdir lib; mkdir bin
$ cd project_makefile
$ make debug
$ ar -r ../lib/libtest[linux_dbg_32].a *.o
$ cd ..; cd test
$ g++ -o test test_makefile_gcc.cpp -L ../lib -ltest[linux_dbg_32]
$ ./test
$ cd ..; cd project_makefile
$ gcc -shared -o ../bin/libtest[linux_dbg_32].so *.o
$ g++ -o ../test/test2 ../test/test_makefile_gcc.cpp -L ../bin -ltest[linux_dbg_32]
$ cd ..; cd test
$ export LD_LIBRARY_PATH=../bin
$ ./test2
GitHub:https://github.com/fengbingchun/Linux_Code_Test
再分享一下我老師大神的人工智能教程吧。零基礎!通俗易懂!風趣幽默!還帶黃段子!希望你也加入到我們人工智能的隊伍中來!https://blog.csdn.net/jiangjunshow
Ubuntu下makefile及gcc生成靜態庫動態庫的簡單使用舉例