StaticLibA是个静态库,提供了如下函数
int Add(int a, int b) { return (a + b); }
StaticLibB也是个静态库,提供了如下函数
int Mul(int a, int count) { int sum = 0; for (int i = 0; i < count; i++) { sum = Add(sum, a); } return sum; }
其中StaticLibB调用了StaticLibA里面的函数Add。
无论StaticLibB是否将StaticLibA包含进去,StaticLibB都能编译通过。
StaticLibTest是main函数所在程序,代码如下所示:
int main() { int c = Mul(10, 9); std::cout << "Hello World!n"; printf("c = %dn", c); while (1); return 0; }
很明显,StaticLibTest直接调用了StaticLibB的函数Mul。
首先:默认情况下,StaticLibB没有将StaticLibA包含进去,此时编译StaticLibTest工程时,不仅需要将StaticLibB.lib链接进去,同时也需要将StaticLibA.lib链接进去。
若StaticLibB将StaticLibA包含进去,则编译StaticLibTest工程时,只需要将StaticLibB.lib链接进去。
静态库StaticLibB链接StaticLibA静态库的配置如下:
通过如此,我更加确定了,静态库只有编译,没有链接,跟动态库有着本质区别。静态库的本质跟obj,linux的.o文件是一个东西。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)