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

时间:2018-03-09 06:48:08

标签: c++ static-libraries api-design

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

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没有编译/链接的情况。这是为了阻止我的库的客户端使用未作为API公开的低级函数。

特别是,如何处理无法声明为静态的函数?

我尝试过的事情:

  • this中所述,我尝试将objcopy与localize隐藏标志一起使用,但没有什么能阻止客户端再次全局化它吗?

  • 导出地图 - 我不知道如何使用静态存档。相反,我根本不知道它们是否适用。

1 个答案:

答案 0 :(得分:1)

不可能。可以将静态库视为所有未链接对象文件的单个文件存档。因此,可见的是链接目标文件的内容从整个静态库中可见。

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