在linux下制作libxxx.so 动态库以及使用方法

在linux下面动态库的使用是非常常用的,也是非常实用的。

步骤一:

创建一个.h头文件 ,头文件中声明动态库中的函数

#ifndef _TEST_H_
#define _TEST_H_

#ifdef __cplusplus       /*c c++ 混合编程*/
extern "C" {
#endif                   /*c c++ 混合编程*/


int max(int a, int b);
int add(int a, int b);

#ifdef __cplusplus        /*c c++ 混合编程*/

}
#endif                   /*c c++ 混合编程*/



#endif


步骤二

创建.c文件实现头文件中的函数

int max(int a, int b){
        if (a > b){
                return a;
        }else{
                return b;
        }
}

int add(int a, int b){
        return a+b;
}

步骤三:
编写makefile文件 ,在编译命令中添加 -shared 参数
在链接命令中添加 -fPIC 参数
该选项指定生成动态连接库;
         -fPIC:位置独立(地址无关)的代码,不用此选项的话,编译后的代码是位置相关的,所以动态载入时,是代码拷贝的方式
 -L:指定链接库的路径,-L. 表示要连接的库在当前目录中,仅仅是做到在编译时连接,并没有将动态库路径添加到运行时查找路径中
 -ltest:指定链接库的名称为test,编译器查找动态连接库时有隐含的命名规则,即在给出的名字前面加上lib,后面加上.so来确定库的名称
       -Wl,-rpath: 记录以来so文件的路径信息,将动态库路径添加到运行时查找路径中。
 LD_LIBRARY_PATH:这个环境变量指示动态连接器可以装载动态库的路径
 那么也就是说,通常是将-L 和 -Wl,-rpath配合使用较好
      当然如果有root权限的话,可以修改/etc/ld.so.conf文件,然后调用 /sbin/ldconfig来达到同样的目的,
      不过如果没有root权限,那么只能采用修改LD_LIBRARY_PATH环境变量的方法了。
.SUFFIXES:.c.o
CC = gcc
SRC = test.c
OBJK = $(SRC:.c=.o)
EXEC = libtest.so
start: $(OBJK)
        $(CC) -shared -o $(EXEC) $(OBJK)
        @echo ---------------ok-------------------
.c.o:
        $(CC) -Wall -fPIC -g -o $@ -c $< 
clean:
        rm -f $(OBJK)
        rm -f $(EXEC)
        rm -f core.*

使用该动态库
 gcc -L动态库所在路径 使用该动态库.c文件 -lXXX 动态库名
 
 g++ main.cpp -L/home/cyd/ -ltest -o test -Wl,-rpath=/home/cyd/
                                                                          


你可能感兴趣的:(在linux下制作libxxx.so 动态库以及使用方法)