被调用的库程序在gnu / linux上的无限循环中运行

时间:2012-11-20 07:26:05

标签: c gcc

我有一个库,必须通过调用

从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

helpversion调用很好,并且在Windows上读取工作正常,我的linux构建特定的东西在这里,但到目前为止我找不到错误。什么可以称这个read在这样的无限循环中运行?

1 个答案:

答案 0 :(得分:2)

read函数在libc.so中定义,用于读取数据。

sqlite3_open()极有可能称之为。

通过引入自己的名为read()的函数,您已使程序进入无限循环。如果你等待的时间足够长,你的程序就会用完堆栈并崩溃。

医生,我这样做会很疼。好吧,不要这样做: - )