与静态库链接
所有的编译系统都提供一种机制,把所有的相关的目标模块打包成为一个单独的文件,称为静态库,它可以用作链接器的输入。当链接器构造一个输出的可执行文件时,它只复制静态库里被应用程序引用的目标模块,(这就减少了可执行文件在磁盘和内存中的大小。)
Linux中静态库以存档的特殊文件格式存放在磁盘中。存档文件是一组连接起来的可重定位目标文件的集合,存档文件名由后缀.a标识。
/* addvec.c */
/* $begin addvec */
int addcnt = 0;
void addvec(int *x, int *y,
int *z, int n)
{
int i;
addcnt++;
for (i = 0; i < n; i++)
z[i] = x[i] + y[i];
}
/* $end addvec */
/* multvec.c */
/* $begin multvec */
int multcnt = 0;
void multvec(int *x, int *y,
int *z, int n)
{
int i;
multcnt++;
for (i = 0; i < n; i++)
z[i] = x[i] * y[i];
}
/* $end multvec */
/* main2.c */
/* $begin main2 */
#include <stdio.h>
#include "vector.h"
int x[2] = {1, 2};
int y[2] = {3, 4};
int z[2];
int main()
{
addvec(x, y, z, 2);
printf("z = [%d %d]\n", z[0], z[1]);
return 0;
}
/* $end main2 */
/* prototypes for libvector */
void addvec(int *x, int *y, int *z, int n);
void multvec(int *x, int *y, int *z, int n);
int getcount();
变成.o文件:gcc -c main2.c addvec.c multvec.c
创建addvec函数和multvec函数的静态库:ar rcs libvector.a addvec.o multvec.o
为了使用这个库,编写了main2.c调用addvec库例程,创建一个可执行文件:gcc -static -o prog2c main2.o -L. -lvector
(或者等价地使用:gcc -static -o prog2c main2.o libvector.a
)
这里-lvector是libvector.a的缩写,-L参数告诉链接器在当前目录查找lib-vector.a。
链接器运行时,它判定main2.o引用了addvec.o定义的addvec符号,所以复制addvec.o到可执行文件。还复制了libc.a中的printf.o模块以及其他C运行时的模块。
注意静态库要写在其他目标文件的后面。
在处理libvector.a时,U(未解析即引用的尚未定义的符号)是空的,所以没有libvector.a中的成员目标文件会加入到E中。所以无法解析对addvec的引用,链接器会产生错误信息并终止。