我正在阅读 O'Reilly 的书21st Century C,其中作者指出在链接静态库时:
编译器 [有效地] 将库的相关内容复制到最终的可执行文件中。
我试图通过创建我自己的包含这个模块的静态库来测试这个:
static char szStr[64];
char* single_func() {
strcpy(szStr, "Hello string!\r\n");
return szStr;
}
void func0() {
strcpy(szStr, "Hello");
}
char* func1() {
strcat(szStr, " string!\r\n");
return szStr;
}
为了测试,我创建了两个 C 文件,其中一个正在调用single_func()
,另一个调用func0()
和func1()
.
在这两种情况下,生成的可执行文件都是 751290B。如果我直接从模块调用strcpy
,strcat
则两个可执行文件最终都是 7215B。
这是否与上述陈述不冲突,还是我错过了有关链接的一些细节?
一个相关的问题是静态库是1600B,那么这个大小的增加是从哪里来的呢?
额外的:
两个主文件都只包含调用函数和打印结果,如下所示:
主要0:
#include <stdio.h>
#include "sharedlib.h"
int main() {
char* szStr = single_func();
printf("%s", szStr);
return 0;
}
主要1:
#include <stdio.h>
#include "sharedlib.h"
int main() {
char* szStr;
func0();
szStr = func1();
printf("%s", szStr);
return 0;
}
文件是这样编译的:
gcc -static main0.c -L. -lsharedlib -o main0
平台是linux,编译器是gcc v4.6.3。