【问题标题】:hiredis SET runs into segmentation faulthiredis SET 遇到分段错误
【发布时间】:2019-11-04 02:03:37
【问题描述】:

我正在尝试使用hiredis 将SET 结构体导入Redis:

struct StatLite
{
    uid_t uid;
    gid_t gid;
    mode_t mode;
}

bool RedisPermissionHandler::Set(std::string path, StatLite stat)
{
    redisReply *reply = (redisReply*)redisCommand(this->redis,
        "SET %b %b",
        path.c_str(), (size_t)path.length(),
        stat, (size_t)sizeof(stat));
    freeReplyObject(reply);
    return true;
}

但是这会在hiredis内部的某个地方遇到分段错误。

this->redispathstat 具有正确的值。 GET 命令有效并提供 NIL 回复类型(因为 Redis 为空)。

我做错了什么?

【问题讨论】:

  • @tadman VSCode 认为redisCommand 返回void*,所以让它闭嘴。
  • 我刚刚查看了文档,哇,是的,它是void*。您确定不想在这里使用 C++ 连接器吗?如果你施放错误,任何事情都可能发生。
  • @tadmanhiredis 是唯一可以通过 linux 软件包 repos 轻松获得的软件。从文档来看,这似乎很简单。不过我愿意接受建议。
  • C 适配器通常必须处理很多 C 限制。您可以使用整个 heap of C++ clients 来代替。当然,其中之一更好。您可以将其构建为库,然后将其折叠到最终的可执行文件中。
  • @tadman 几乎所有这些都包含hiredis或需要提升。那怎么办?

标签: c++ linux redis segmentation-fault hiredis


【解决方案1】:

这里的问题是您指定的是原始结构而不是指向该结构的指针:

bool RedisPermissionHandler::Set(std::string path, StatLite stat)
{
    redisReply *reply = (redisReply*)redisCommand(this->redis,
        "SET %b %b",
        path.c_str(), (size_t)path.length(),
        &stat, (size_t)sizeof(stat) // Pointer to stat!
    );

    freeReplyObject(reply);
    return true;
}

很可能驱动程序正在寻找特定大小的void* 缓冲区并将stat 视为void*,从而在取消引用该指针时导致段错误。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2017-08-20
    • 1970-01-01
    • 1970-01-01
    • 2020-08-03
    相关资源
    最近更新 更多