共享库中的符号

时间:2015-08-03 10:30:02

标签: c++ c gcc shared-libraries

我已完成this tutorial here以了解如何生成共享库。我添加了一些较小的东西,因为我想测试一些东西。这是ma源代码:

强文

#ifndef foo_h__
#define foo_h__

void foo(void);

class CFoo
{
public:
    void fooing1();
    void fooing2(int a);
    void fooing3(int a, int b = 0);
};

#endif      // foo_h__

Foo.cpp中

#include <stdio.h>
#include "foo.h"

void foo(void)
{
    puts("Hello, I'm a shared library");
}

void CFoo::fooing1()
{
    puts("CFoo::fooing1()");
}

void CFoo::fooing2(int a)
{
    printf("CFoo::fooing2(%d)\n", a);
}

void CFoo::fooing3(int a, int b)
{
    printf("CFoo::fooing3(%d, %d)\n", a, b);
}

的main.c

#include <stdio.h>
#include "foo.h"

int main(void)
{
    puts("This is a shared library test...");
    foo();

    CFoo *foo1 = new CFoo();
    foo1->fooing1();
    foo1->fooing2(12);
    foo1->fooing3(1);
    foo1->fooing3(1, 2);
    delete foo1;


    return 0;
}

构建脚本

g++ -c -Wall -Werror -fpic foo.cpp
g++ -shared -o libfoo.so foo.o
g++ -Wall -o test main.c -lfoo -L.

输入命令nm -D libfoo.so | c++filt时,我得到了这个输出:

 0000000000201040 B __bss_start
                  w __cxa_finalize
 0000000000201040 D _edata
 0000000000201048 B _end
 0000000000000818 T _fini
                  w __gmon_start__
 0000000000000640 T _init
                  w _ITM_deregisterTMCloneTable
                  w _ITM_registerTMCloneTable
                  w _Jv_RegisterClasses
                  U printf
                  U puts
 0000000000000796 T foo()
 00000000000007a8 T CFoo::fooing1()
 00000000000007c2 T CFoo::fooing2(int)
 00000000000007ea T CFoo::fooing3(int, int)

我有两个问题:

1)为什么printfputs在其功能名称之前有U?函数foo()CFoo::fooing1()CFoo::fooing2(int)CFoo::fooing3(int, int)在函数名称之前确实有T

2)如何在U功能之前获得CFoo

1 个答案:

答案 0 :(得分:2)

您生成的库代码中未定义符号printfputs的{​​{3}}。这是正常的,因为它们是在另一个共享库中定义的。

字母T表示代码在库文件中定义(文本部分实际上对应于代码;不应与数据部分混淆)。

如果CFoo函数是您共享库的核心内容,那么最好避免在库中创建它们。如果你想要达到这个目的:

  • 将此CFoo函数保留在类标题
  • foo.cpp中完全删除它:代码将编译但函数丢失(即库文件中根本没有定义)
  • 但是从CFoo中的另一个foo.cpp函数调用此函数:代码将编译,这次库文件将此函数定义为U:定期声明符号whic,是需要,但尚未找到。