静态链接库其实就是把一个或多个目标文件(即编译生成的.o文件)归档在一个文件中。此后,当需要使用这个静态库中的某个功能时,将这个静态库与要生成的应用程序链接在一起。 来讲讲ar工具~~~~ 在Linux上平台上最常用的归档工具是GNU的tar,但是要构建静态库却不能使用tar,而要使用另一个工具ar。tar和ar都是归档工具,但是它们的目的是不同的。tar仅仅是用来创建归档文件(即通常以.tar为后缀的文件)的,ar也完成上述工作,但是做了一些额外的处理,它会为被归档的目标文件中的符号建立索引,当和应用程序链接时,建立的这些索引将回收链接过程。 ar比较经常用到的就是有三个命令选项:r(插入)、c(创建)和s(建立索引),而且这三个选项往往是一起使用。参数r:在库中插入模块(替换)。当插入的模块名已经在库中存在,则替换同名的模块。如果若干模块中有一个模块在库中不存在,ar显示一个错误消息,并不替换其他同名模块。默认的情况下,新的成员增加在库的结尾处,可以使用其他任选项来改变增加的位置。参数c:创建一个库。不管库是否存在,都将创建。参数s:创建目标文件索引,这在创建较大的库时能加快时间。(补充:如果不需要创建索引,可改成大写S参数;如果。a文件缺少索引,可以使用ranlib命令添加) 现在假设有两个C文件,foo.cbar.c。首先将foo.c和bar.c编译为目标文件foo.o和bar.o,然后将这两个目标文件归档为一个静态链接库。 [cpp] view plaincopyprint? 1 // bar.c 2 3 #include "foobar.h" 4 5 char * bar(void) 6 7 { 8 9 printf("This is bar! library1 iscalled\n"); 10 11 return ("bar"); 12 13 } [html] view plaincopyprint? 14 //foo.c 15 16 #include "foobar.h" 17 18 char * foo(void) 19 20 { 21 22 printf("This is foo!library2 iscalled!\n"); 23 24 return ("foo"); 25 26 } 继续~~~~~ [cpp] view plaincopyprint? 27 //foobar.h 28 29 #ifndef _FOOBAR_H_ 30 31 #define _FOOBAR_H_ 32 33 34 35 #include <stdlib.h> 36 37 #include <string.h> 38 39 #include <stdio.h> 40 41 extern char *foo(void); 42 43 extern char *bar(void); 44 45 #endif 执行下令命令:~~~~ [cpp] view plaincopyprint? 46 #gcc -c foo.c -o foo.o 47 48 #gcc -c bar.c -o bar.o 49 50 #ar rcs libfoobar.a foo.o bar.o 这基于PC平台的,如果是对于嵌入式平台的构建静态链接库而言,过程也是完全一样,唯一需要改变的可能是所用的工具名称。比如,如果要是为ARM-Linux构建静态库,那么可能需要使用arm-linux-ar。这里还有一个工具是nm,它可以用来取得目标文件的符号(symbol)信息。这里,nm打印出了libfoobar.a中的两个符号:foo和bar。这两个符号表示的都是函数,因此它们的符号值为0,符号类型为T(text,即表示该符号位于代码段) 最新评论 |