linux中.so后缀的文件怎么使用?

linux中.so后缀的文件怎么使用?,第1张

在WINDOWS系统中有很多的动态链接库(以.DLL为后缀的文件,DLL即Dynamic Link Library)。这种动态链接库,和静态函数库不同,它里面的函数并不是执行程序本身的一部分,而是根据执行程序需要按需装入,同时其执行代码可在多个 执行程序间共享,节省了空间,提高了效率,具备很高的灵活性。同样,LINUX的也具备类似的动态链接库,而且为数不少。在/lib目录下,就有许多以.so作后缀的文件,这就是LINUX系统应用的动态链接库,只不过与WINDOWS叫法不同,它叫so,即Shared Object,共享对象。(在LINUX下,静态函数库是以.a作后缀的) X-WINDOW作为LINUX下的标准图形窗口界面,它本身就采用了很多的动态链接库(在/usr/X11R6/lib目录下),以方便程序间的共享, 节省占用空间。flash只是一个插件,在windows中就是一个ocx的链接库方式(和dll略有不同),因此linux中一旦你了一个共享函数库,你还需要安装它。其实简单的方法就是拷贝 \x0d\x0a你的库文件到指定的标准的目录(例如/usr/lib),然后运行ldconfig。 \x0d\x0a如果你没有权限去做这件事情,例如你不能修改/usr/lib目录,那么 \x0d\x0a你就只好通过修改你的环境变量来实现这些函数库的使用了。首先, \x0d\x0a你需要创建这些共享函数库;然后,设置一些必须得符号链接,特别 \x0d\x0a是从soname到真正的函数库文件的符号链接,简单的方法就是运行ldconfig: \x0d\x0aldconfig -n directory_with_shared_libraries \x0d\x0a然后你就可以设置你的LD_LIBRARY_PATH这个环境变量,它是一个以逗号 \x0d\x0a分隔的路径的集合,这个可以用来指明共享函数库的搜索路径。例如 \x0d\x0a,使用bash,就可以这样来 \x0d\x0a启动一个程序my_program: \x0d\x0aLD_LIBRARY_PATH=.LD_LIBRARY_PATH my_program

可以啊,只要保证你执行端(访问端)是IE就行了,

调用OCX控件,查一下HTML中使用控件,网上一大堆。

另外,OCX中,一般都有包含调用是否成功的函数,这个你要

知道OCX的接口

C一般不能直接调用C++函数库,需要将C++库封装成C接口后,才可以使用C调用。

下面举例,说明一个封装策略:

//code in add.cxx

#include "add.h"

int sample::method()

{

cout<<"method is called!\n"

}

//code in add.h

#include

using namespace std

class sample

{

public:

int method()

}

将上面的两个文件生成动态库libadd.so放到 /usr/lib目录下,编译命令如下:

sudo g++ -fpic -shared -g -o /usr/lib/libadd.so add.cxx -I ./

由于在C中不能识别类,所以要将上面类的成员函数,要封装成C接口函数才能被调用。下面进行封装,将输出接口转换成C接口。

//code in mylib.cxx

#include "add.h"

#ifndef _cplusplus

#define _cplusplus

#include "mylib.h"

#endif

int myfunc()

{

sample ss

ss.method()

return 0

}

//code in mylib.h

#ifdef _cplusplus

extern "C"

{

#endif

int myfunc()

#ifdef _cplusplus

}

#endif

在linux下,gcc编译器并没用变量_cplusplus来区分是C代码还是C++ 代码(没有宏定义),如果使用gcc编译器,这里我们可以自己定义一个变量_cplusplus用于区分C和C++代码,所以在mylib.cxx中定义 了一个变量_cplusplus用于识别是否需要“extern "C"”将函数接口封装成C接口。但是如果使用g++编译器则不需要专门定义_cplusplus,编译命令如下:

g++ -fpic -shared -g -o mylib.so mylib.cxx -la -I ./

main.c

#include

#include

#include "mylib.h"

int

main()

{

int (*dlfunc)()

void *handle//定义一个句柄

handle = dlopen("./mylib.so", RTLD_LAZY)//获得库句柄

dlfunc = dlsym(handle, "myfunc")//获得函数入口

(*dlfunc)()

dlclose(handle)

return 0

}

编译命令如下:

gcc -o main main.c ./mylib.so -ldl

下面就可以执行了。

需要说明的是,由于main.c 和 mylib.cxx都需要包含mylib.h,并且要将函数myfunc封装成C接口函数输出需要“extern "C"”,而C又不识别“extern "C"”,所以需要定义_cplusplus来区别处理mylib.h中的函数myfunc。

在main.c的main函数中直接调用myfunc()函数也能执行,这里介绍的是常规调用库函数的方法。


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

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

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

发表评论

登录后才能评论

评论列表(0条)

保存