day 3
vim demo.c
gcc demo.c -o demo
gcc -Wall demo.c 显示所有隐式警告
库文件:存放函数和变量的仓库,特点:只能使用库里的函数和变量,不能看到其实现
静态库.a:当使用静态库时,库里的函数和变量是在编译时加载到可执行文件
动态库.so:当使用动态库时,库里的函数和变量是在运行时加载到可执行文件的
可执行文件的大小:静态库>动态库------内存使用效率不高
可执行文件的速度:静态库>动态库 >运行效率
可执行文件的功能升级:静态库<动态库 ----->功能升级的难易程度
可执行文件的代码部署:静态库>动态库 ----->代码部署的位置
int addd(int a,int b)
{
return a+b;
}
mainc.c
#include <stdio.h>
int main ()
{
printf(“add = %d\n”,add(5,6));
return 0;
}
extern int add(int,int);
root@jsetc-virtual-machine:~/test1# vim add.c
root@jsetc-virtual-machine:~/test1# vim ad.c
root@jsetc-virtual-machine:~/test1# vim add.h
root@jsetc-virtual-machine:~/test1# ls
ad.c add.c add.h
root@jsetc-virtual-machine:~/test1# gcc ad.c add.c -o add
root@jsetc-virtual-machine:~/test1# ls
ad.c add add.c add.h
root@jsetc-virtual-machine:~/test1# ./add
add=11
gcc -o 1 1.c //将1.c编译成.exe文件,我们可以用此命编译出代码。
库文件的存放位置:/lib/uer/lib
cp …/add.h . 将上一级的add.h文件复制到当前这一级目录
gcc main.c -ladd -L. 静态编译
*** ./a.out ***
如何制作静态库和动态库:
静态库
gcc -c 源文件
ar rcs 库文件名字 目标文件
gcc 源文件 -l库名 -L 库的路径
动态库
gcc -shared -fPIC 源文件 -o 库名
gcc 源文件 ./库名 -o 可执行文件
gcc -fPIC add.c -o libcal.so
gcc -shared -fPIC add.c -o libcal.so
gcc ad.c ./libcal.so -o ad
-o是用来给文件重新命名的 (比如让ad.c 变为ad)
制作静态库步骤详例
(1)gcc -c 源文件
gcc -c min.c
min.o (可执行文件)
(2)ar rcs 库文件名字 目标文件
ar rcs add.h
libadd.a
(3)gcc 源文件 -l库名 -L 库的路径
root@jsetc-virtual-machine:~/test1/kk# ls
add.h libadd.a libmin.a main.c min.h
root@jsetc-virtual-machine:~/test1/kk# gcc main.c -ladd -lmin -L.
root@jsetc-virtual-machine:~/test1/kk# ls
add.h a.out libadd.a libmin.a main.c min.h
root@jsetc-virtual-machine:~/test1/kk# ./a.out
add=12
min=2
制作动态库步骤详例
(1)gcc -shared -fPIC 源文件 -o 库名
gcc -shared -fPIC add.c min.c -o libadd.so libmin.so
libadd.so libmin.so这两个是执行完上条命令之后生成的
(2)gcc 源文件 ./库名 -o 可执行文件名称
gcc main.c ./libadd.so ./libmin.so -o main(不能两个同时生成的话就分开写)
main
./main