我已完成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)为什么printf
和puts
在其功能名称之前有U
?函数foo()
,CFoo::fooing1()
,CFoo::fooing2(int)
和CFoo::fooing3(int, int)
在函数名称之前确实有T
?
2)如何在U
功能之前获得CFoo
?
答案 0 :(得分:2)
您生成的库代码中未定义符号printf
和puts
的{{3}}。这是正常的,因为它们是在另一个共享库中定义的。
字母T表示代码在库文件中定义(文本部分实际上对应于代码;不应与数据部分混淆)。
如果CFoo函数是您共享库的核心内容,那么最好避免在库中创建它们。如果你想要达到这个目的:
CFoo
函数保留在类标题foo.cpp
中完全删除它:代码将编译但函数丢失(即库文件中根本没有定义)CFoo
中的另一个foo.cpp
函数调用此函数:代码将编译,这次库文件将此函数定义为U:定期声明符号whic,是需要,但尚未找到。