SQLite第四课 创建windows动态库

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SQLite第四课 创建windows动态库相关的知识,希望对你有一定的参考价值。

下载源码包两个:

sqlite-dll-win32-x86-3081101.zip,里面提供了导出sqlite3的函数的文件sqlite3.def

主要用于生成LIB文件,确定链接使用

sqlite-preprocessed-3081101.zip,提供了源码文件,但是删除shell.ctclsqlite3.c文件

 

1.新建win32控制台程序,名称sqlite3

 

2.选择生成DLL

 

3.解压压缩包,将sqlite-preprocessed-3081101的文件复制到工程文件夹下(除了shell.c以及tclsqlite.c)

 

4.通过添加存在文件,将源码添加到编译项目中

 

 

5设置模块定义文件sqlite3.def,否则生成的dll没有对应的lib

 

 

7.添加预定义选项SQLITE_CORE,SQLITE_ENABLE_COLUMN_METADATASQLITE_ENABLE_RTREE,这是sqlite3的宏定义。

 

8.F7生成相应的dlllib

 

编译小细节:

 

指定函数的导出文件:sqlite3.defs

属性》》链接器》》输入》》模块定义文件(sqlite3.def),请注意这种情况下,sqlite3.def文件和编译环境平级。

后果:不会生成sqlite3.lib文件

指定预编译宏:

属性》》C/C++》》预处理器》》预处理定义》》

SQLITE_CORE

SQLITE_ENABLE_COLUMN_METADATA

SQLITE_ENABLE_RTREE

后果:

1>sqlite3.def : error LNK2001: 无法解析的外部符号sqlite3_column_database_name

1>sqlite3.def :error LNK2001: 无法解析的外部符号sqlite3_column_database_name16

1>sqlite3.def :error LNK2001: 无法解析的外部符号sqlite3_column_origin_name

1>sqlite3.def :error LNK2001: 无法解析的外部符号sqlite3_column_origin_name16

1>sqlite3.def :error LNK2001: 无法解析的外部符号sqlite3_column_table_name

1>sqlite3.def :error LNK2001: 无法解析的外部符号sqlite3_column_table_name16

1>sqlite3.def :error LNK2001: 无法解析的外部符号sqlite3_rtree_geometry_callback

1>sqlite3.def :error LNK2001: 无法解析的外部符号sqlite3_rtree_query_callback

前面6个函数,必须定义了SQLITE_ENABLE_COLUMN_METADATA才能够将函数导出,一般情况下,这些函数,我们可以直接在sqlite3.def文件中删除,不导出

后面2个函数,必须定义了SQLITE_ENABLE_RTREE才能够将函数导出,如果我们不适用R树的空间搜索功能,这些函数,我们可以直接在sqlite3.def文件中删除,不导出


以上是关于SQLite第四课 创建windows动态库的主要内容,如果未能解决你的问题,请参考以下文章

SQLite3动态库静态库编译

产品经理进阶第四课,Axure实操之动态面板的状态切换

产品经理进阶第四课,Axure实操之动态面板的状态切换

Windows下静态动态库的封装和使用(图解)

Windows下静态动态库的封装和使用(图解)

Qt第四课 搭建工程环境