Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1333200
  • 博文数量: 436
  • 博客积分: 7854
  • 博客等级: 少将
  • 技术积分: 3225
  • 用 户 组: 普通用户
  • 注册时间: 2007-12-18 16:30
文章分类

全部博文(436)

文章存档

2013年(2)

2012年(56)

2011年(70)

2010年(308)

分类:

2010-06-02 16:59:36

动态链接库是一种通用的软件组件技术,是多种操作系统中提供基本服务的方式。比如Win32内核就是3个DLL文件构成。这种技术在Linux操作系统下也有对应的实现,就是Linux标准对象Standard Ojbect,对应的文件扩展名为.so。

下面通过一个简单的例子开始介绍Linux标准对象。
我们的标准对象文件含有一个函数,不需要声明export导出符号,只需要编译器设置即可。如下:

#include
#include

void show() {
printf("Standard Object by gashero\n");
}

保存为myso.c文件,按照如下编译:

$ gcc -fPIC -shared -o libmyso.so myso.c

执行生成一个libmyso.so文件,按照Linux标准对象的命名惯例,应该在库名称之前加上"lib"前缀,尽管不是必须的。编译开关-fPIC代表函数符号可以重定向,-shared代表编译结果是一个标准对象。

不同于Win32DLL,Linux标准对象中的所有函数都是直接导出的,都可以被调用程序所访问。下面我们编写调用程序:

#include

int main() {
printf("Invoke my so\n");
show();
return 0;
}

保存为invoke.c,按照如下gcc开关编译:

$ gcc -o test invoke.c ./libmyso.so

编译生成test可执行文件。如上编译条件的最后一条需要是所调用的标准对象文件名,注意必须含有路径。如果只是使用libmyso.so,则必须确保这个文件在可访问的PATH下面。本例所使用的文件名"./libmyso.so"是当前路径下的,使用了相对路径。

如下测试结果:

$ ./test
Invoke my so
Standard Object by gashero
//////////////////////////////////////////////////////////////////////////////////////
按照上边的方法的确编出来了,但是为什么把文件改成CPP的再编译就不成了呢?用的是G++???
//////////////////////////////////////////////////////////////////////////////
执行命令:
g++ -fPIC -shared -o libmyso.so myso.cpp
g++ -o test invoke.c ./libmyso.so
错误信息:
invoke.cpp: In function `int main(int, char**)':
invoke.cpp:9: error: `show' undeclared (first use this function)
invoke.cpp:9: error: (Each undeclared identifier is reported only once for each function it appears in.)
/////////////////////////////////////////////////////////////////////////
阅读(256) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~