linux中建立自己的静态库 动态库并使用

库依赖:
gcc connect.c –o connect –I /usr/include/mysql –L /usr/lib/mysql -lmysqlclient
//-I是找到自己写的头文件所在的位置 -L是找到自己所写的动态库所在的位置,并且写上函数名,静态库不用写-L,只写函数名//-I 是i 的大写

先编译一边,会发现报错,然后解析一下,没有包含头文件

添加上头文件-I /usr/local/include/mysql后,在编一下,发现还有函数没有识别出来,是因为没有包含相应的库文件。

然后将库文件添加上以后,在进行编译发现问题搞定了


这些操作都是在test的文件夹下做的,如果不是的话,用-I 和-L -I来找到头文件的的位置,-L和动态库的位置,

//在test的文件夹下有 main.c xiangjia.c xianjian.c xiangjia.h xiangjian.h//都是自己写的

main.c中

#include <stdio.h>//正常写法
#include "mymath.h"//自己定义的
int main()
{ 
  int t=xiangjia(65,4);
  int z=xiangjian(45,2);
  printf("%d %d\n",t,z);
  return 0;
}

xiangjia.c中

int xiangjia(int a,int b)
{
  return a+b:
}

xiangjian.c中

int xiangjian.(int a,int b)
{
  return a-b;
}

mymath.h中

#ifndef MYMATH_H   //如果没有定义这个头文件
#define MYMATH_H  //那么定这个
  int xiangjian(int a,int b);//xxx.c中的函数的声明
  int xiangjia(int a,int b);
#endif

静态操作
[root@localhost test]# gcc -c main.c xiangjia.c xiangjian.c //然后对所有的.c文件进行转换,变成.o目标文件
[root@localhost test]# ar cr libmylib.a xiangjian.o xiangjia.o //然后用ar cr 对.o文件进行操作,转换成静态库,并起个名字,格式:libxxxx.a
[root@localhost test]# gcc -o mylib main.o libmylib.a //然后,使用-o对main.o 和已经生成的静态库libxxxxx.a重命名,
[root@localhost test]# ./mylib //然后找到重命名的文件进行测试,运行 :/找到路径/名字
110
20


动态操作
[root@localhost test]# gcc -shared -fPCI -o libmyname.so xiangjian.o xiangjia.o //使用这个命令,对静态所生成的函数目标文件,进行重命名,格式:libxxxxx.so

[root@localhost test]# cp -r libmyname.so /lib //然后复制所生成的libxxxxx.so即动态文件到 /lib文件夹下

[root@localhost Desktop]# gcc -o mymath ./test/main.c -L /lib/ -lmyname //然后对/路径/main.c 重命名 为 xxxxxx(mymath),并使用-L 找到/lib/ -lxxxx(即libxxxxx.so的缩写),添加这个路径
[root@localhost Desktop]# ./mymath
110
20
[root@localhost Desktop]#

猜你喜欢

转载自www.cnblogs.com/NirobertEinteson/p/10219224.html