我刚刚将一堆源代码提取到了几个静态库中,以使项目更加结构化,并且主要可执行文件的二进制大小增加了约 150kb。这让我很困惑,所以我用三个文件制作了一个小项目:
foo.c:
int foo1(void) { return 1; }
int foo2(void) { return 2; }
...
int foo100(void) { return 3; }
bar.c:
int bar1(void) { return 1; }
int bar2(void) { return 2; }
...
int bar100(void) { return 4; }
main.c:
int main(int argc, const char * argv[]) {
int acc = 0;
acc += foo1();
acc += bar1();
acc += foo2();
acc += bar2();
...
acc += foo100();
acc += bar100();
printf("%d\n", acc);
}
在我制作了两个可执行文件和一个静态库之后:
libfoo.a:
foo.o
bar.o
test_no_lib:
main.o
foo.o
bar.o
test_with_lib:
main.o
libfoo.a
它们的大小相差约 2kb(~31kbtest_no_lib
和 ~33kb test_with_lib
,在 macos 上使用 clang 11 编译,-Os 优化,所有符号都被剥离)。
这是为什么?静态库不应该只是目标文件的存档,如果需要,链接器会获取这些目标文件吗?为什么它也增加了尺寸?它不是很多,但它仍然让我感到惊讶,为什么它不是免费的?