代码改变世界

gcc dynamic load library

2017-09-28 11:18  woodzcl  阅读(598)  评论(0编辑  收藏  举报

Linux下一般都是直接在编译生成时挂接上链接库,运行时,把链接库放到系统环境里就可以了

但是windows出现带来了动态链接的概念,也就兴起了非windows世界的插件的概念的范潮

对应于windows下的

LoadLibrary

GetProcAddress

FreeLibrary

Linux提出了

dlopen

dlsym

dlclose

的相关系统调用

哎,全是抄啊!!!!

一把泪

好了,我想你应该明白怎么回事了吧

下面,带你进入linux动态加载库的世界

这个是由libdl库来运作的噢!!!

 

//caculate.c

int add(int a, int b)
{
  return a+b;
}
int sub(int a, int b)
{
  return a-b;
}
int mul(int a, int b)
{
  return a*b;
}
int div(int a, int b)
{
  return a/b;
}

//main.c

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


#define LIB_CACULATE_PATH "./libcaculate.so"


typedef int(*CAC_FUNC)(int, int);


int main()
{
  void *handle = NULL;
  char *error = 0;
  CAC_FUNC cac_func = NULL;
  handle = dlopen(LIB_CACULATE_PATH, RTLD_LAZY);
  //handle = dlopen(LIB_CACULATE_PATH, RTLD_NOW);
  if (!handle)
  {
    fprintf(stderr, "%s\n", dlerror());
    exit(EXIT_FAILURE);
  }
  dlerror();
  cac_func = (CAC_FUNC)dlsym(handle, "add");
  if (cac_func)
  {
    printf("add: %d\n", cac_func(2, 7));
  }
  cac_func = (CAC_FUNC)dlsym(handle, "sub");
  if (cac_func)
  {
    printf("sub: %d\n", cac_func(9, 2));
  }
  cac_func = (CAC_FUNC)dlsym(handle, "mul");
  if (cac_func)
  {
    printf("mul: %d\n", cac_func(3, 2));
  }
  cac_func = (CAC_FUNC)dlsym(handle, "div");
  if (cac_func)
  {
    printf("div: %d\n", cac_func(8, 2));
  }
  dlclose(handle);


  return 0;
}

//生成库和调用者

gcc -o caculate.o -c caculate.c
gcc -fPIC -shared -o libcaculate.so caculate.o

gcc -o main.o -c main.c
gcc -o main -ldl main.o

//运行与结果

我们的调用者main将要调用libcaculate.so动态库

./main
add: 10
sub: 12
mul: 24
div: 2

 

Finally:

看这个世界哪里都一样啊!

好了,大家去搞插件去吧!!!

对了,忘了告诉你了,插件已经早就不流行了,哈哈哈

但我觉得历史是不应该被忘记的,记住这个阶段,对于你应该有重大意义的啊

现在,我们的这个世界流行的是Web,“一切皆服务,一切皆应用”