静态库中的符号可见性和操作

Symbol visibility and manipulation in static libraries

我正在尝试从我的源文件中创建一个静态库。为了说明我面临的问题,让我们考虑以下片段:

foo.h:

void public_fn_exposed_to_client();

foo.cpp:

#include "foo.h"
#include <iostream>
#define EXPORT __attribute__ ((visibility ("default")))

static void private_fn() {
    std::cout << "Hello private world" << std::endl;
}

// Can't declare static as this can be used elsewhere in my lib.
// I tried to make this symbol hidden.

void internal_fn_used_inside_lib(){
    std::cout << "Hello Internal Wolrd" << std::endl;

}

EXPORT
void public_fn_exposed_to_client()
{ 
    std::cout << "Hello Outside World" << std::endl;
    internal_fn_used_inside_lib(); 
}

main.cpp(通常由客户写):

#include "foo.h"
int main(int argc, char** argv)
{
     // This is all good.
     public_fn_exposed_to_client();
}

main2.cpp(通常由客户写):

#include "foo.h"
extern void internal_fn_used_inside_lib();
int main(int argc, char** argv)
{
    // Ideally, This should not be allowed
    internal_fn_used_inside_lib();
}

编译:

g++ -o foo.o foo.c -fvisibility=hidden
ar rcs libfoo.a foo.o
ranlib libfoo.a

g++ -o main1 main.cpp -L. -lfoo
g++ -o main2 main2.cpp -L. -lfoo

我想实现main2没有得到的情况compiled/linked。这是为了阻止我的库的客户使用未公开为 API 的较低级别的函数。

特别是如何处理不能声明为静态的函数?

我尝试过的事情:

不可能。可以将静态库视为所有未linked 目标文件的单个文件存档。因此,可见的是 link 个目标文件从整个静态库中可见。

"hide" 的唯一方法是不提供头文件,但没有什么能阻止用户自己重新创建这些头文件。