Chinaunix首页 | 论坛 | 博客
  • 博客访问: 626251
  • 博文数量: 79
  • 博客积分: 848
  • 博客等级: 军士长
  • 技术积分: 1800
  • 用 户 组: 普通用户
  • 注册时间: 2012-06-26 19:30
文章分类

全部博文(79)

文章存档

2015年(4)

2013年(39)

2012年(36)

分类: C/C++

2012-07-23 11:30:00

今天boss给分配了一些编程的任务要求,每一个方法形成一个.so库,一听之下有点蒙了,以前编程中还真没有用过这个玩意!各种找资料,现在就把一些比较基本的东西来整理一下,以供参考!
什么是.so文件呢?so是unix的动态连接库,是二进制文件,作用相当于windows下的.dll文件,这一说大家大概就明白了,其实.so就是在我们在运行时动态调用的一个库文件,为什么我们要使用.so呢,其实是这样我们有时候在编程的过程中,遇到一类问题的解决需要我们抽象出共有的对象在c++中我们称之为基类,但是具体的实现需要有他的子类来完成,这样的情况下一般假如后续要修改程序的话我们只要修改子类的内容,基类是不会修改的,这样我们可以把子类的实现封装在一个.so文件中,在运行时动态加载它。修改时也只需要修改这个子类文件重新编译成.so即可。这样就大大增加了程序的可移植性,是一个良好的编程习惯!
说了这么多,到底怎么来使用.so文件呢,下面我来举一个很简单的例子!这里用到了三个文件。
test.h:
#inlude
using namespace std;
void hello();
test.cpp
#include"test.h"
void hello()
{
         cout<<"hello world"<}
hello.cpp
#include"test.h"
int main()
{
        hello();
         return 0;
}
我们这里将test.cpp打包成.so文件:
g++ test.cpp -shared -o libtest.so
在编译hello.cpp的时候动态的加载它:
g++ hello.cpp -L. -ltest -o hello
我们可以通过ldd的命令看看是否加载了该动态库libtest.so;
ldd hello

linux-gate.so.1 =>  (0xb7771000)
libtest.so => /usr/lib/libtest.so (0xb7759000)
libstdc++.so.6 => /usr/lib/i386-linux-gnu/libstdc++.so.6 (0xb766e000)
libc.so.6 => /lib/i386-linux-gnu/libc.so.6 (0xb74ef000)
libm.so.6 => /lib/i386-linux-gnu/libm.so.6 (0xb74c5000)
/lib/ld-linux.so.2 (0xb7772000)
libgcc_s.so.1 => /lib/i386-linux-gnu/libgcc_s.so.1 (0xb74a7000)

这样我们发现已经加载了该库文件;
./hello
就能得到我们执行的结果了!
加载过程中遇到的问题:
肯能会出现库找不到的情况,因为系统在执行命令的时候/usr/lib中找我们的库文件,我只需加一个软链接就行了;
sudo ln -s ~/libtest.so /usr/lib/test.so
这样就能够正确执行了!!!
阅读(4109) | 评论(4) | 转发(0) |
给主人留下些什么吧!~~

风箫夜吟2012-07-24 11:38:37

Aquester: so不用主函数,也可以执行,链接时指定一个函数就可以了.....
恩是啊 我就这么做的呀!!例子中不就是在hello.cpp中为.so指定了一个主函数嘛

Aquester2012-07-24 11:03:43

风箫夜吟: 是啊,但是必须得有主函数才行,我现在的想法是这样的;我想把多个子类的实现打包成.so;每个子类定义了基类函数的一种实现方式,当你需要不同的功能时,只需要在.....
so不用主函数,也可以执行,链接时指定一个函数就可以了

风箫夜吟2012-07-24 10:55:22

Aquester: so本身也可以直接运行的.....
是啊,但是必须得有主函数才行,我现在的想法是这样的;我想把多个子类的实现打包成.so;每个子类定义了基类函数的一种实现方式,当你需要不同的功能时,只需要在运行时链接不同的.so文件来实现多态,所以.so中没有主函数

Aquester2012-07-23 19:10:00

so本身也可以直接运行的