Chinaunix首页 | 论坛 | 博客
  • 博客访问: 575109
  • 博文数量: 50
  • 博客积分: 571
  • 博客等级: 中士
  • 技术积分: 1162
  • 用 户 组: 普通用户
  • 注册时间: 2012-01-20 14:01
个人简介

希望成为一个有思想,有信仰的程序设计师。

文章分类

全部博文(50)

文章存档

2016年(2)

2015年(2)

2014年(13)

2013年(10)

2012年(23)

分类: C/C++

2012-08-14 15:07:58

这个问题是我在使用sqlite3时遇到的,在我的程序中需要用到sqlite数据库。但是在官网上下载的sqlite开发包中只有sqlite3.dll和sqlite3.def文件。
要想在自己的程序调用sqlite3中的函数,有两种方法--动态链接(隐式链接)和静态链接(显式链接)。

第一种:动态链接主要是利用LoadLibrary、GetProcAddress、FreeLibrary这三个api

LoadLibrary
HINSTANCE LoadLibrary(LPCTSTR lpLibFileName);
The LoadLibrary function maps the specified executable module into the address space of the calling process. 
这个函数就是映射可执行模块的地址到调用这个函数的进程中,以便这个进程能够调用可执行模块中的函数。
输入参数: lpLibFileName 指向一个可执行模块的名字的字符串,在这里也就是指向"sqlite3.dll"的字符指针,你也可以加路径,请注意要用back slashes(\)代替forward slashes(/)。具体的请参看MSDN。
返回值:成功的话就返回这个可执行模块的句柄(下面要用),否则返回NULL。
GetProcAddress
FARPROC GetProcAddress(  HMODULE hModule,  LPCSTR lpProcName );
The GetProcAddress function returns the address of the specified exported dynamic-link library (DLL) function.
这个函数返回动态链接库(DLL)中指定函数的地址,为了下面可以调用这个指定的函数。
输入参数:
hModule 就是调用LoadLibrary得到的句柄。
lpProcName字符指针,指向函数名(这个函数必须是dll中定义的函数)。
返回值:函数指针,是对应上面函数名的函数的入口地址。
FreeLibrary
BOOL FreeLibrary( HMODULE hLibModule  );
The FreeLibrary function decrements the reference count of the loaded dynamic-link library (DLL) module. When the reference count reaches zero, the module is unmapped from the address space of the calling process and the handle is no longer valid. 
这个函数就是释放我们load的dll模块。当有多次load的时候,我们一次释放一个。
输入参数:就是上面调用LoadLibrary得到的句柄。
返回值:失败为0,否则为非0
下面给出一个小例子
typedef int(*SQLITE3_OPEN)(const char *filename,sqlite3 **ppdb);
SQLITE3_OPEN sqlite3_open;
HINSTANCE hdll;
int init_dll_function(void)
{
      hdll=LoadLibrary("sqlite3.dll");
      if(hdll==NULL){printf("Error to LoadLibrary!\n");return 1;}
      sqlite3_open=(SQLITE3_OPEN)GetProcAddress(hdll,"sqlite3_open"); 
      if(sqlite3_open==NULL){
            printf("Error!\n");
            return 1;
      }
if(!FreeLibrary(hdll)){
return 1;
}
return 0;
}

第二种:静态(显式)链接

第一步:
这个比较简单,首先利用def文件生成一个lib文件。
如何用def文件生成一个lib文件?
到C:\Program Files\Microsoft Visual Studio\VC98\Bin下(如果VC是装在C盘的话),用CMD进入到这个目录下,然后利用lib.exe这个程序来生成所要的lib。具体的命令是:LIB /DEF:sqlite3.def /machine:IX86
。你运行了这个命令发现会有问题,因为这边默认是sqlite3.def在当前文件夹下(C:\Program Files\Microsoft Visual Studio\VC98\Bin),如果你这个文件不在这个文件夹下,那么就会出错,你只要把sqlite3.def文件复制到这个文件夹下就可以了,然后生成的lib文件也是在这个文件夹下的,你可以将它复制到你需要的地方。
注意:好像有的VC在安装的时候差什么文件,运行lib.exe命令的时候会出错,你只要找到那个差的文件并复制到当前的文件夹下,就可以了。(那个缺少文件有可能是放在其他文件夹了,你可以查找一下,我的就是这种情况)。
第二步:在程序中添加#pragma comment(lib,"sqlite3.lib") ,并且添加相应的头文件(sqlite3.h).
第三步:就在程序中调用你想要调用的函数。



阅读(11946) | 评论(0) | 转发(1) |
给主人留下些什么吧!~~