编译共享对象库,调用函数
Compile shared object library, which call function from so too
我有一个f2.cpp文件
// f2.cpp
#include <iostream>
void f2()
{
std::cout << "It's a call of f2 function" << std::endl;
}
我使用cygwin和交叉编译器gcc。
g++ -fPIC -c f2.cpp
g++ -shared -o libf2.so f2.o
我有一个电梯。所以文件。现在我想调用f2函数在f1库(共享对象)libf1.so.
它是f1.cpp,我想取f1.so
// f1.cpp
#include <iostream>
void f1()
{
std::cout << "f1 function is calling f2()..." << std::endl;
f2();
}
如何编译f1.cpp?我不想使用dlclose, dlerror, dloopen, dlsym…Аt最后我想用f1。所以在main.cpp作为一个共享对象库也是…不使用使用dlclose, dlerror, dlopen, dlsym。我必须如何编译main.cpp,当我将有一个f1。
?// main.cpp
#include <iostream>
int main()
{
f1();
return 0;
}
在头文件中声明f2()并编译libf1。和libf2很像
现在编译f1和f2的主链接。它应该是这样的g++ -lf2 -lf1 -L /path/to/libs main.o
您可以简单地将它们链接在一起(如果f2
被编译成libf2.so
,则将-lf2
传递给链接器)。链接器将负责连接从f1
到f2
的调用。自然地,在运行时 f1
将期望在SO加载路径中找到f2
,并且动态加载器将加载它。
下面是一个更完整的示例,取自我发现的Makefile的一部分。这里,mylib
代表您的f2
, main_linked
代表f1
:
mylib: mylib.c mylib.h
gcc $(CFLAGS) -fpic -c mylib.c
gcc -shared -o libmylib.so mylib.o
main_linked: main_linked.c mylib.h mylib.c
gcc $(CFLAGS) -L. -lmylib main_linked.c -o main_linked
注意:
-
mylib
与-shared
编译成共享库 -
main_linked
然后用单个gcc
调用来构建,传递-lmylib
来指定要链接的库,并传递-L.
来说明在哪里可以找到它(在这种情况下-当前目录)
检查g++的-L和-L标志
相关文章:
- 如何用参数值调用函数(仅在运行时已知)
- 从python中调用C++函数并获取返回值
- 当使用通配符和null指针调用函数时,对输出的说明
- 从R调用C++函数并对其进行集成时出错
- 使用QTreeView,如何通过调用函数只突出显示特定的行/列
- 如何在qt中从另一个类调用函数
- 在 COUT 语句中使用 COUT 调用函数
- 如何从线程中的不同模块调用函数?
- C++从函数指针数组调用函数
- 当 A 在 for 循环中调用函数 B 时,如何计算函数 A 的空间复杂度?
- 如何在 C/C++ 中从外部库调用函数
- 如何使用运算符在同一行中多次调用函数
- 是否可以创建一个从不同类调用函数的线程?
- 无法为类成员调用函数
- 如何从另一个标头 c++ 调用函数
- C++有什么方法可以在既不调用函数模板也不提供其模板参数的情况下引用函数模板?
- 如何只允许在调用函数 B 后调用函数 A?
- 我可以这样调用函数吗?
- 如何在 c++ 的类中递归调用函数方法?
- 为什么在指向对象的迭代器上调用函数不允许我更改对象本身?