提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档
前言
当要把程序给别人,但不想让他看到原代码的时候,可以将程序编译成“库”发给他。相当于对程序进行了加密,别人可以使用,但看不到里面的内容。
一、静态库与动态库?
①.静态库在程序编译时会被连接到目标代码中,程序运行时将不再需要该静态库。
②.动态库在程序编译时并不会被连接到目标代码中,而是在程序运行是才被载入,因此在程序运行时还需要动态库存在。
静态库
优点:
1.静态库被打包到应用程序中加载速度快
2.发布程序无需提供静态库,因为已经在app中,移植方便
缺点:
1.链接时完整地拷贝至可执行文件中,被多次使用就有多份冗余拷贝,浪费内存空间。
2.更新、部署、发布麻烦。
动态库
优点:
1.链接时不复制,程序运行时由系统动态加载到内存,供程序调用,系统只加载一次,多 个程序可以共用,节省内存。
2.程序升级简单,因为app里面没有库的源代码,升级之后只要库的名字不变,函数名以及参数不变,只是实现做了优化,就能加载成功。
缺点:
1.加载速度比静态库慢
2.发布程序需要提供依赖的动态库
二、静态库的制作及使用
1.命名规则
静态库文件名的命名方式是**“libxxx.a”**
库名前加“lib”,后缀用“.a”,“xxx”为库名
2.制作步骤
hello.h
#ifndef HELLO_H
#define HELLO_H
void hello(const char *name);
#endif
hello.c
#include <stdio.h>
void hello(const char *name)
{
printf("Hello, %s!\n", name);
}
main.c
#include "hello.h"
int main(int argc, char * argv[])
{
hello("C Programmer");
return 0;
}
我们将hello.c编译成静态库文件,步骤如下
- 原材料:hello.c
- 生成“.o”文件:gcc hello.c -c
- 将“.o”文件打包,生成静态库文件:
ar rcs libhello.a hello.o
ar rcs:静态库打包指令
libhello.a:静态库名字
hello.o:原材料
3.库的使用
gcc main.c -I /usr/include -L ./ -lhello -o main
-I(大写i):指定头文件路径
-L:指定库文件的路径
-l(小写L):指定库的名字(去掉lib和.a)
示例:
三.动态库的制作及使用
1.命名规则
动态库的后缀为“.so”,前缀和静态库一样。所以为“libhello.so”
2.制作步骤
- 生成“.o”文件:gcc hello.c -c
- 打包:gcc -shared -fpic hello.o -o libhello.so
-shared: 指定生成动态库
-fpic: 生成位置无关的代码
3.库的使用
与静态库的指令一样
gcc main.c -I /usr/include -L ./ -lhello -o main
但此时./main的话,会提示No such file or directory,因为系统不知道库的路径,有2种解决方法:
1.将库cp到/usr/lib中
2.进行环境变量的设置。
在终端进行设置:
export LD_LIBRARY_PATH=动态库的路径:$LD_LIBRARY_PATH
不过这是临时的,并不是永久有效。不过我们可以建立一个shell文件,后面直接运行shell文件即可。