我有一个库,必须通过调用
从sqlite数据库中读取数据extern int read(char** argv, int argc); // from header
必须处理:
int read(char** argv, int argc) {
char* lineborder1;
char* lineborder2;
char* spaces1;
char* spaces2;
int maxl2 = 0, maxl1 = 0;
int i, maxi1, maxi2;
if (prelude() == -1) return -1;
// etc...
其中prelude是sqlite连接的内部过程:
int prelude() {
timefile = 0;
f = NULL;
#ifndef WIN32
char* temp = (char*)calloc(200, sizeof(char));
#endif
queries = (char**)malloc(sizeof(char*) * q_cnt);
for (x = 0; x < q_cnt; x++) {
queries[x] = (char*)malloc(sizeof(char) * q_size);
}
#ifdef WIN32
retval = sqlite3_open("todo.db3", &handle);
#else
home = (char*)getenv("HOME");
strcpy(temp, home);
retval = sqlite3_open(strcat(temp, "/.todo.db3"), &handle);
free(temp);
#endif
if (retval) {
printf("Database connection failed\n\r");
return -1;
}
return 0;
}
整个来源在这里:bitbucket: ctodo.c
我从我的应用程序中读取此内容:
else if ((strcmp(argv[1], "read") == 0) || (strcmp(argv[1], "r") == 0)) {
return read(argv, argc);
但是获得此read
来电的无限循环:
>>./todo r
Database connection failed
Database connection failed
Database connection failed
.... etc
这是我如何构建它:
gcc -I . -c -o todo.a ctodo.c -lsqlite3 -O3
gcc -I . -o todo cctodo.c -lsqlite3 -O3 todo.a
help
或version
调用很好,并且在Windows上读取工作正常,我的linux构建特定的东西在这里,但到目前为止我找不到错误。什么可以称这个read
在这样的无限循环中运行?
答案 0 :(得分:2)
read
函数在libc.so
中定义,用于读取数据。
sqlite3_open()
极有可能称之为。
通过引入自己的名为read()
的函数,您已使程序进入无限循环。如果你等待的时间足够长,你的程序就会用完堆栈并崩溃。