Linux下制做静态库和动态库

制做库文件并使用

1.什么是库文件?

所谓库文件,就是一堆函数的集合。linux

一堆函数源码的集合 -> ***.c 一堆二进制函数代码的集合 -> ***.so -> 用户能够调用库里面的函数,可是没有办法看到函数的实现过程。bash

2.库的格式?

在linux里面,库有两种,一种是静态库 -> libxxxx.a 另一种是动态库/共享库 -> libxxxx.so函数

3.库文件名字的含义

例子: libabc.so.0.8接口

lib -> 库的前缀 abc -> 库的名字 -> 在工程中连接库文件时须要使用。 .so -> 库的后缀 .0 -> 库的版本号 .8 -> 库的修正号编译器

4.静态库的特色

例子: libxxxx.a -> 去图书馆(libxxxx.a)把图书(函数)借走 1)在程序编译时,须要连接静态库,其实就等价于把库的东西拿走,就致使了可执行程序大小的比较大! 2)因为是静态编译,因此在编译程序以后,不须要库文件(libxxxx.a)存在也能够执行。源码

5.动态库的特色

例子: libxxxx.so -> 去图书馆(libxxxx.so)看看书(函数接口),看(编译是连接)完就放回去,可是再次想看书(调用函数),就必须再去图书馆(库文件必需要存在)。编译

1)在程序编译时,须要连接动态库,可是并无把库的东西带走,因此可执行程序的大小相对小。 2)因为动态编译,因此编译完程序以后,库文件必须存在才能执行程序。class

库文件如何制做

库文件只能将一些不包含main函数在内的.c文件制做成库文件。 不是main函数的函数写入.c文件 -> 再将.c文件制做为库文件。变量

1.静态库的制做

project.c -> 调用fun1()和fun2() fun1()和fun2()都属于功能函数。gcc

1)将工程中不包含main函数在内的.c文件编译为.o文件 gcc fun1.c -o fun1.o -c gcc fun2.c -o fun2.o -c

2)将全部.o文件的塞进一个.a文件 -> 库文件的名字你本身定! ar rcs libmy.a fun1.o fun2.o

3)编译程序,连接库文件。 gcc project.c -o project -L . -lmy -L . 在当前目录下寻找库文件 -lmy 指定连接my这个库 -> 注意-l后面是没有空格!

4)执行 ./project -> 不须要库的存在也能够!

静态库使用于不含main函数在内的.c文件较小时。

2.动态库的制做

1)将工程中不包含main函数在内的.c文件编译为.o文件 gcc fun1.c -o fun1.o -c -fPIC gcc fun2.c -o fun2.o -c -fPIC

2)制做动态库须要使用gcc编译器 gcc -shared -fPIC -o libmy2.so fun1.o fun2.o

3)编译程序 gcc project.c -o project -L . -lmy2 -> 没有拷贝库中的内容。

4)执行 ./project

//执行project找不到库文件的路径 ./project: error while loading shared libraries: libmy2.so: cannot open shared object file: No such file or directory

解决方案一: 系统默认去/lib寻找库文件,只须要将libmy2.so放置到/lib便可。 解决方案二: 指定系统还能够去哪一个路径下寻找库文件 -> 使用环境变量 LD_LIBRARY_PATH export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/home/gec -> 永久修改写入: .bashrc

4)从新执行 ./project helloworld! hello! helloworld!

相关文章
相关标签/搜索