用g++编译生成动态连接库*.so的方法及连接
用g++编译生成动态连接库*.so的方法及连接
1、动态库*.so的编译
这里我们用到4个文件,它们分别为:SoDemoTest.h、one.cpp、two.cpp、three.cpp。它们的内容如下:
SoDemoTest.h
- #ifndef __SO_DEMO_TEST_HEADER__
- #define __SO_DEMO_TEST_HEADER__
- #include <iostream>
- using namespace std;
- void one();
- void two();
- void three();
- #endif
one.cpp
- #include "SoDemoTest.h"
- void one()
- {
- cout << "call one() function." << endl;
- }
two.cpp
- #include "SoDemoTest.h"
- void two()
- {
- cout << "call two() function." << endl;
- }
three.cpp
- #include "SoDemoTest.h"
- void three()
- {
- cout << "call three() function." << endl;
- }
将这几个文件编译成动态库libtest.so。编译命令如下:
$ g++ one.cpp two.cpp three.cpp -fPIC -shared -o libtest.so
2、动态库的连接
在上面的部分,我们已经生成了一个libtest.so的动态链接库,现在我们用一个程序来调用这个动态链接库。文件名为:main.cpp
main.cpp
- #include "SoDemoTest.h"
- int main()
- {
- one();
- two();
- three();
- return 0;
- }
将main.cpp与libtest.so链接成一个可执行文件main。命令如下:
$ g++ main.cpp -L. -ltest -o main
测试可执行程序main是否已经链接的动态库libtest.so,如果列出了libtest.so,那么就说明正常链接了。可以执行以下命令:
$ ldd main
执行main可以看看main是否调用了动态链接库中的函数。
3、编译参数
-shared 该选项指定生成动态连接库(让连接器生成T类型的导出符号表,有时候也生成弱连接W类型的导出符号),不用该标志外部程序无法连接。相当于一个可执行文件
-fPIC:表示编译为位置独立的代码,不用此选项的话编译后的代码是位置相关的所以动态载入时是通过代码拷贝的方式来满足不同进程的需要,而不能达到真正代码段共享的目的。
-L.:表示要连接的库在当前目录中
-ltest:编译器查找动态连接库时有隐含的命名规则,即在给出的名字前面加上lib,后面加上.so来确定库的名称
LD_LIBRARY_PATH:这个环境变量指示动态连接器可以装载动态库的路径。
4、注意的问题
调用动态库的时候有几个问题会经常碰到,有时,明明已经将库的头文件所在目录 通过 “-I” include进来了,库所在文件通过 “-L”参数引导,并指定了“-l”的库名,但通过ldd命令察看时,就是死活找不到你指定链接的so文件,这时你要作的就是通过修改 LD_LIBRARY_PATH或者/etc/ld.so.conf文件来指定动态库的目录。通常这样做就可以解决库无法链接的问题了。
转载于:https://www.cnblogs.com/hehehaha/archive/2013/01/16/6333015.html
用g++编译生成动态连接库*.so的方法及连接相关推荐
- 用g++编译生成动态连接库*.so的方法及连接(dlopen() dlsym() dlclose())
================================================================ //test_so_file.h ifndef TEST_SO_FIL ...
- PHP连接mysql数据库使用方法,PHP连接MySQL数据库的操作方法
下面是小编给大家分享的一篇PHP连接MySQL数据库的操作方法,或许能开阔眼界,增长见识,体验乐趣,下面就跟随中国E盟技术频道的编辑一起来看看. 关于PHP与MySQL的合作,不外乎以下三种方法: 1 ...
- c语言怎么连接库,C语言库函数的连接
以前没怎么注意这个,知道今天搞驱动的时侯才注意到!我在debugman上自问自答,这里在写的详细一点: 现在最新的WDK6001.18002,改了驱动入口点 /entry:GsDriverEntry@ ...
- java连接MySQL几种方法_Java连接MySQL数据库三种方法
好久没有更新博客了!今天利用周目时学习了一下数据库mysql.介绍一下数据库的三种连接方式! 开发工具:Myeclipse MySQL5.6 MySQL连接驱动:mysql-connector-jav ...
- 苹果炉石传说显示无法连接服务器,《炉石传说》无法连接到战网解决方法 无法连接请检查网络连接如何快速解决...
导 读 炉石传说无法连接请检查网络连接怎么办?无法连接到战网怎么解决?近期游戏进行了版本更新,在本次的更新中,有很多玩家都出现了各式各样的bug,其中最频繁的一个就是提示无法连接,请检查网络连接或者显 ...
- 炉石传说显示无法连接服务器失败,《炉石传说》无法连接到战网解决方法 无法连接请检查网络连接如何快速解决...
炉石传说无法连接请检查网络连接怎么办?无法连接到战网怎么解决?近期游戏进行了版本更新,在本次的更新中,有很多玩家都出现了各式各样的bug,其中最频繁的一个就是提示无法连接,请检查网络连接或者显示无法连 ...
- linux 动态扫描 数码管,七段数码管动态扫描原理及其实现方法
MCU输出端口Dig1控制第一个数字的公共阳极 MCU输出端口Dig2控制第二个数字的公共阳极 打开和关闭MCU输出端口A,B,C,D,E,F,G,DP控制段图片 如何动态显示数字电子管? A,B,C ...
- linux等陆不上ftp,vsftp连接不上解决方法
当前位置:我的异常网» Linux/Unix » vsftp连接不上解决方法 vsftp连接不上解决方法 www.myexceptions.net 网友分享于:2015-08-26 浏览:0次 v ...
- asp adodb连接mysql数据库语句_ASP连接MySQL数据库的方法
ASP连接MySQL数据库的方法 ASP连接MySQL数据库的方法 ASP等语言连接mysql数据库,可以通过安装mysql的ODBC驱动,通过配置ODBC数据源,连接并操作数据库. mysql od ...
最新文章
- 2020最新点云深度学习综述
- centos7 利用 crontab 执行 定时任务 计划任务
- iOS 混合网页开发 问题
- PL/SQL Developer 使用技巧小结(转)
- Tp框架中模板中if条件如何使用?
- tomcat6配置log4j日志
- PHP和javascript中url编码解码详解
- 云之讯 亿美 短信的三方接口
- paip.VS2010未能加载类型
- android 关机 流程_Android 关机(reboot)流程
- 【锐捷校园网用电脑开热点】简明教程
- Pycharm代码跳转
- 用友NC合同编码自定义
- 计算机那个是固态硬盘,固态硬盘的好处是什么?电脑使用固态硬盘有什么用
- vmware设置固定ip
- 华为手机序列号前三位_华为Nova2s手机序列号前六位是TPG4C1是什么意思
- 3.11 污点和容忍度
- 【JavaWeb】9—监听器
- Array.isArray()判断是否为数组
- 爬虫小案例之爬取京东商品链接
热门文章
- HashMap的结构及源码分析
- 计算机辅助设计b实验目的,上海电力学院电路计算机辅助设计1--含有受控源电路辅助分析...
- java二维数组遍历排序,实现二维数组的按次序排序!!!
- 计算机硬件教学设计高中信息,重大版信息技术七上《计算机硬件系统》教学设计.doc...
- oracle+循环插入sql,SQL server,Oracle循环插入百万数据
- oracle 性能优化 常用,Oracle數據庫常用性能優化
- java把收集的数据节点_java面试题收集(04)
- mysql 当前timestamp_MySQL表结构使用timestamp以自动获取当前时间
- 可以批量转modis投影_SNAP批量处理Sentinel2数据
- 大数据技术之kafka (第 3 章 Kafka 架构深入) Zookeeper 在 Kafka 中的作用