0

我刚刚将一堆源代码提取到了几个静态库中,以使项目更加结构化,并且主要可执行文件的二进制大小增加了约 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 优化,所有符号都被剥离)。

这是为什么?静态库不应该只是目标文件的存档,如果需要,链接器会获取这些目标文件吗?为什么它也增加了尺寸?它不是很多,但它仍然让我感到惊讶,为什么它不是免费的?

4

1 回答 1

0

我已经想通了。静态库使用不同的可见性设置(默认)编译,因此链接器必须保留重定位信息,即使所有符号名称都被剥离。

于 2019-11-21T19:57:34.710 回答