Bootstrap

Linux下简单编译so库,调用另一个so库的方法

linux下将c/c++编译成so库

gcc -fPIC -shared Cat.c -o libcat.so

-fPIC是压制警告
-shared是生成动态库
Cat.c是要编译的文件
-o是要生成的文件的名称

linux下将c/c++生成可执行文件

gcc -rdynamic -o main main.c -ldl

-rdynamic是生成可执行文件
-o是生成的文件的名称
main.c是要编译的文件
-ldl可以理解为要生成一个动态库吧(这个不是太懂)

之后会在当前目录下生成一个main文件
直接./main就可以执行了

下面举个例子

首先写了一个Cat.c

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

然后把Cat.c编译成一个so库

gcc -fPIC -shared Cat.c -o libcat.so

执行完之后会在当前路径下生成一个libcat.so文件


在写一个main方法,这里写了一个main.c

#include <stdio.h>
#include <stdlib.h>
#include <dlfcn.h>

typedef int (*ADD)(int,int);

int main(){
    #这里调用刚才生成的so库里的add方法
    void *handle=dlopen("./libcat.so",RTLD_LAZY);
    ADD add=NULL;
    *(void **)(&add)=dlsym(handle,"add");
    int result=add(2,5);
    printf("%d\n",result);
    return 0;
}

之后将main.c生成一个可以执行的文件main

gcc -rdynamic -o main main.c -ldl

执行之后会在当前路径下生成一个main文件

直接./main就会打印:7,也就是调用了刚才那个so库方法里的add方法

;