学习自狄泰软件学院唐佐临老师C语言课程,文章中图片取自老师的PPT,仅用于个人笔记。




实验1
20-1.c
#include <stdio.h>
extern char* name();
extern int add(int a, int b);
int main()
{
printf("Name: %s\n", name());
printf("Result: %d\n", add(2, 3));
return 0;
}
slib.c
char* name()
{
return "Static Lib";
}
int add(int a, int b)
{
return a + b;
}
将 slib.c 制作成一个静态库:
第一步:将原程序编译成目标文件 : gcc -c slib.c -o slib.o
第二步:生成静态库文件 : ar -q slib.a slib.o //其实就是将 一些列.o文件打包进 slib.a文件
第三步:使用静态库以及目标文件编译源文件生成可执行文件 : gcc 20-1.c slib.a -o test.out
mhr@ubuntu:~/work/C$
mhr@ubuntu:~/work/C$ gcc -c slib.c -o slib.o
mhr@ubuntu:~/work/C$ ar -q slib.a slib.o
ar: creating slib.a
mhr@ubuntu:~/work/C$ ls
20-1.c 20-2.c dlib.c slib.a slib.c slib.o
mhr@ubuntu:~/work/C$
mhr@ubuntu:~/work/C$
mhr@ubuntu:~/work/C$ gcc 20-1.c slib.a -o test.out
mhr@ubuntu:~/work/C$ ./test.out
Name: Static Lib
Result: 5
mhr@ubuntu:~/work/C$


实验2:创建和使用动态库
20-2.c
#include <stdio.h>
#include <dlfcn.h>
int main()
{
void* pdlib = dlopen("./dlib.so", RTLD_LAZY);//打开动态库
char* (*pname)();
int (*padd)(int, int);
if( pdlib != NULL )
{
pname = dlsym(pdlib, "name");
padd = dlsym(pdlib, "add");
if( (pname != NULL) && (padd != NULL) )
{
printf("Name: %s\n", pname());
printf("Result: %d\n", padd(2, 3));
}
dlclose(pdlib);
}
else
{
printf("Cannot open lib ...\n");
}
return 0;
}
dlib.c
char* name()
{
return "Dynamic Lib";
}
int add(int a, int b)
{
return a + b;
}
编译动态库源码生成动态库

使用动态库编译源文件得到可执行文件,执行可执行文件的条件是 动态库必须存在,不然找不到动态库,动态库是不会包含在可执行程序里面的。


问题:为什么需要动态库,难道静态库不够用吗?
答案:比如某些应用程序经常更新,这些更新都做了什么事情呢?他们往往只是做了一小部分改动,这时候动态库的优势就体现出来,只需要修改替换某些对应的动态库就可以了。现代软件产品中,假如需要升级的时候,将最终的程序连接到服务器上面,将需要的动态库下载下来,然后程序重启之后就能使用新的动态库了,这样的好处就是部分更新应用程序。

被折叠的 条评论
为什么被折叠?



