链接反对.a,但仍然需要.a,所以?(C++,linux)

Linking against .a, but still need .so? (C++, linux)

本文关键字:所以 linux C++ 链接      更新时间:2023-10-16

在什么情况下,我会将应用程序链接到一堆.a文件,但在运行时仍然需要.so文件?

在什么情况下,我会将一个应用程序与一堆的.a文件,但在运行时仍需要.so文件?

需要在运行时加载特定.so的情况

例如,您可能有两个共享对象库(.so's):

RealCarLibrary
TestCarLibrary

但是,您需要在运行时加载Test库或Real库,这取决于用户的环境变量$CAR_LIB的设置

typedef int (*runCar_ptr)();
const char* env_variable = std::getenv("CAR_LIB");
void *sharedObject_ptr = nullptr;
if(env_variable == "test" )
{
   sharedObject_ptr =dlopen("/path/to/TestCarLibrary.so", RTLD_NOW);
}
else
{
  sharedObject_ptr = dlopen("/path/to/RealCarLibrary.so", RTLD_NOW);
}
runCar_ptr *runCarFunctionPtr = dlsym(sharedObject_ptr, "RunTheCar");
runCarFunctionPtr();

.A与.so的简介:

存档库(.a)是静态链接的(在编译时)。生成的二进制文件包含您创建的程序和库。

共享对象库(.so)在运行时加载。它们的总体内存占用率较低,因为它们实际上并没有添加到您正在创建的二进制文件中。

至于为什么选择使用静态库,您必须查看静态库的专业知识

To guarantee(at build time) that an application's libraries are present and that they are the correct version.

有关共享对象库与静态对象库的更多信息,请参阅此和此。