使用vs2005单步调试sqlite3.6.23
来源:互联网 发布:球形轮胎 知乎 编辑:程序博客网 时间:2024/06/04 23:20
网上大多数的使用vs2005编译sqlite是编译成为dll,我的目的是为了分析sqlite,所以还是编译成一个可执行程序方便单步调试
1.创建一个空的Win32 Console Application工程,
2.sqlite3.6.23的所有源码均加入工程,除去以下几个
shell.c 可去可不去,不去的话,可生成执行SQL的输入控制吧,方便调试;去掉的话,需要自已编写一个测试的C文件,
3.选择合适的RuntimeLibrary,默认为多线程模式。位置:Project->Properties->Configuration Properties->C/C++->Code Generation->Runtime Library,这个没有改,就是默认多线程的
4.将编译模式改为c模式(TC)。位置:Project->Properties->Configuration Properties->C/C++->Advanced->Compile As。默认的是C++的,这个需要改
5.如果想要取得不必要的警告信息,则作如下处理:
位置: Project->Properties->Configuration Properties->C/C++->Preprocessor->Preprocessor Definitions
- disable 制定的警告信息(Project->Properties->C/C++->Advanced->Disable Specific Warnings): 4267;4244;4018;4311;4996;4312;4311
6.将fts3_tokenizer.c中27行的
/*
#if !SQLITE_CORE
int sqlite3_extension_init(
sqlite3 *db,
char **pzErrMsg,
const sqlite3_api_routines *pApi
){
SQLITE_EXTENSION_INIT2(pApi)
return sqlite3RtreeInit(db);
}
#endif
*/
56行改为
/*
#ifndef SQLITE_CORE
#include "sqlite3ext.h"
SQLITE_EXTENSION_INIT1
#else
#include "sqlite3.h"
#endif
*/
#include "rtree.h"
外部引用有问题,估计功能不完善,先这么改
7.编译,在shell.c中的main函数设断点就可以单步执行了
icu是internationalcomponents forunicode,如果需要则需另外下载相关头文件。这个网站上不去,所以没加上去
- 使用vs2005单步调试sqlite3.6.23
- 使用vs2005单步调试sqlite3.6.23
- mysql 在 VS2005上面单步调试
- 采用vs2005对sqlserver 2005 SP进行单步调试
- vs2005单步调试不了,设置断点没有用的解决办法
- 【转载】VS2005单步调试变量错误解决方法
- CodeBlocks使用与单步调试
- CodeBlocks使用与单步调试
- 使用spyder编译器单步调试python
- 使用CLion单步调试Caffe
- 使用 Eclipse 单步调试 Zephyr 程序
- 使用 OpenOCD 进行单步调试
- 关于VS2005和VS2008调试时,有些代码不能单步调试问题
- 单步跟踪调试
- eclipse单步调试
- MyEclipse单步调试
- matlab 单步调试
- python: 单步调试
- 纯C 字符串操作函数 实现 (strcpy, strncpy, memcpy, memset, strcat, strlen ... )
- iPhone 5 创建应用程序
- poj1338 poj2591 poj2545 这三道题
- 开源分布式文件系统 MogileFS 和 FastDFS
- android LinearLayout和RelativeLayout实现精确布局
- 使用vs2005单步调试sqlite3.6.23
- sgu 185(最短路+最大流)
- 图像处理与机器视觉的主要任务
- 在Backtrack5中使用msfconsole出现Pcaprub module is not available错误
- 线程同步之semaphore
- 基于 perl 的 webserver 负载均衡
- 一些标准
- Mysql 存储过程简介
- 使用ext3grep恢复ext3上删除的文件zz