C - 尝试将函数的返回值赋给变量会导致分段错误

时间:2015-02-15 20:12:03

标签: c redis

我会尝试仅发布重要部分,因为整个程序有1000多行。它通常不会崩溃,运行好几天。今天我一直在尝试实现一些Redis函数来与程序进行通信,以便从MySQL数据库中获取新数据。

int RedisCheckIfUpdate(redisContext *redis_c) {
    redisReply *redis_reply;
    redis_reply = redisCommand(redis_c, "GETSET update_status 0");

    if (redis_reply->type == REDIS_REPLY_STRING) {
        if (strcmp(redis_reply->str, "newsticker") == 0) {
            freeReplyObject(redis_reply);
            return 1;
        } else if (strcmp(redis_reply->str, "slides") == 0) {
            freeReplyObject(redis_reply);
            return 2;
        }
    }

    freeReplyObject(redis_reply);
    return 0;
}

int main(int argc, char **argv) {
    int redis_update_status;

    redisContext *redis_c;
    redis_c = redisConnect((char*)"127.0.0.1", 6379);

    if (redis_c->err) {
        printf("Connection error: %s\n", redis_c->errstr);
        redisFree(redis_c);
        exit(1);
    }

    while (1) {
        redis_update_status = RedisCheckIfUpdate(redis_c); // THIS SINGLE LINE CAUSES INSTANT SEGFAULT!
        RedisCheckIfUpdate(redis_c); // THIS WORKS 

        if (RedisCheckIfUpdate(redis_c) == 1) {
            MYSQLNewsticker(con, &nt);
        } else if (RedisCheckIfUpdate(redis_c) == 2) {
            MYSQLSlides(con, &pl);
        }             
    }
}

这一行...

redis_update_status = RedisCheckIfUpdate(redis_c);

...导致程序在第一次循环迭代时立即崩溃。一旦我发表评论,即使调用了相同的函数,它也不会崩溃并继续运行 - 只是没有将返回值分配给任何东西。

我可能有一些解决方法,但我只是不明白为什么会这么错?它不是那么复杂的功能,我想要实现的是将返回值赋给变量。变量没有其他任何事情发生。如果我注释掉所说的那行,我甚至会收到一条警告,说在编译期间redis_update_status未被使用...

编辑:我已经删除了除了函数体“返回0”之外的一切,它仍然崩溃了!

1 个答案:

答案 0 :(得分:0)

就像有些人在评论中指出的那样,分段错误是由我发布的代码之外的东西引起的:

char time_formatted[30], date_formatted[30];

// Redis connect stuff

while (1) {
    // redis_update_status = RedisCheckIfUpdate(); part goes here
    (...)

    // BEGIN header
    TextMid(1760, 970, time_formatted, SegoeUISB, 60);
    RGBA(41, 39, 39, 1, temp_fill_color);
    vgSetParameterfv(temp_fill, VG_PAINT_COLOR, 4, temp_fill_color);
    vgSetPaint(temp_fill, VG_FILL_PATH);
    WTextMid(1760, 935, date_formatted, SegoeUI, 19);
    // END header

    (...)

    // BEGIN update datetime values
    time(&rawtime);
    timeinfo = localtime(&rawtime);
    strftime(time_formatted, 30, "%H:%M", timeinfo);
    wcsftime(date_formatted, 30, L"%A, %d.%m.%Y", timeinfo);
    // END update datetime values
}

正如您所看到的,我试图从字符串变量中绘制时钟和日期文本,这些变量在第一次迭代时没有设置为任何东西。在循环开始时移动更新日期时间值部分后,我能够正确运行整个程序,包括Redis部分。

这是一个非常愚蠢的错误,我必须在编程程序的过程中很早就做出这个错误,而且几个星期以来一直没有引起注意。对我来说唯一令人难以置信的事情是,为什么直到现在这几周都没有崩溃,当时我添加了一个简单的Redis功能,与崩溃的部分完全无关......