linuxqt直接调用.a中的函数失败

linuxqt直接调用.a中的函数失败,第1张

linuxqt直接调用.a中的函数失败

1:创建静态

qtCreator创建库,->c++ 库,选静态链接库。

创建出库后,发现相比动态库少了一个xxxx_global.h的文件,在类名前面也没有了导出关键字的修饰,接下来在默认的类中,直接添加一个函数,编译,生成了a文件。

2:写主程序来调用a文件

同样写一个界面程序,把a库的头文件拷贝到现在新建项目的新建include文件夹中,在程序用,包含这个头文件,并用这个类定义一个对象,然后调用对象的自己添加的那个方法。

3:修改pro文件,把头文件路径和库文件路径写入。库文件路径,可以用 -L -l的方法来,也可以直接指定全路径下的库文件名,如下:

LIBS += -L/root/Downloads/testlibS -ltestlibS

LIBS+= /root/Downloads/testlibS/libtestlibS.a

这两种写法都可以,同样,如果用第一种写法,testlibS还是项目的名称。如果是第二种写法,就要完全指定路径和编译生成的库文件的全称了

静态库在程序编译时会被连接到目标代码中,程序运行时将不再需要该静态库。 动态库在程序编译时并不会被连接到目标代码中,而是在程序运行是才被载入,因此在程序运行时还需要动态库存在。 程序1: hello.h #ifndef HELLO_H #define HELLO_H void hello(const char *name)#endif //HELLO_H 程序2: hello.c #include void hello(const char *name) { printf("Hello %s!\n", name)} 程序3: main.c #include "hello.h" int main() { hello("everyone")return 0} 无论动态库还是静态库都需要用到.o文件来生成,先编译生成.o文件。 # gcc -c hello.c 1:创建静态库 静态库文件名的命名规范是以lib为前缀,紧接着跟静态库名,扩展名为.a。例如:我们将创建的静态库名为myhello,则静态库文件名就是libmyhello.a。 # ar cr libmyhello.a hello.o 使用静态库:只需要在你的源程序中加入包含你所需要使用到的函数的声明(即包含头文件),然后在gcc生成目标文件时候指明静态库就OK了(除非你包含的头文件在/usr/include,库文件在标准库/usr/lib,/lib下,否则你得显示指明他们的路径) # gcc -o hello main.c -L. -lmyhello # ./hello Hello everyone! 删除静态库文件运行./hello,程序正常运行,说明静态库公用函数已经链接到目标文件。 2: 利用.o文件创建动态库 动态库文件扩展名为.so。 # gcc -shared -fPCI -o libmyhello.so hello.o 动态库的使用与静态库使用方式一样 # gcc -o hello main.c -L. -lmyhello # ./hello ./hello: error while loading shared libraries: libmyhello.so: cannot open shared object file: No such file or directory 哦!出错了。快看看错误提示,原来是找不到动态库文件libmyhello.so。程序在运行时,会在/usr/lib和/lib等目录中查找需要的动态库文件。若找到,则载入动态库,否则将提示类似上述错误而终止程序运行。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/7085333.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-01
下一篇 2023-04-01

发表评论

登录后才能评论

评论列表(0条)

保存