3

我有一段 C++Qt代码接收网络消息并将其解码为由智能指针管理的 Google protobuf。该函数对 protobuf 进行一些最小的结构解析,以查看是否存在可选消息字段,如果存在某些消息片段,则调度信号。

目前,这些信号包含包含整个消息的智能指针的副本,利用引用计数。但是,我想将智能指针分派到消息的特定部分,以便下游处理程序不需要重新解析整个 protobuf。我不能简单地创建一个指向相关消息部分的新智能指针,因为当新指针超出范围时,它将尝试释放该部分。

试图说明这一点,省略一些安全检查:

void Interface::processProtobuf(QByteArray const & networkData) {

    QSharedPointer<proto_message> msg(new proto_message);

    msg->ParseFromArray(networkData.data(), networkData.length());

    if (msg->has_configuration()) {

        // This will eventually attempt to free, thus causing corruption
        // of msg.
        QSharedPointer<config_message> cfg(msg->mutable_configuration());
        emit configurationChanged(cfg);

        // I resorted to this, which forces the receiver to re-parse
        // the data structure (which might be expensive for a deeply-nested
        // message) to get the desired 'configuration' pointer.
        emit configurationChanged(msg);
    }
}

这样做,我真的需要一种方法来创建一个“相关”子指针,该子指针继承(并增加)父指针上的引用计数,以便在所有子和父都用完之前不会调用数据析构函数范围。此功能在标准智能指针实现之一中可用,还是我创建了不必要的特殊情况?我发现最接近的是Qt's QSharedDataPointer<>,但我认为它在创建子指针的情况下没有帮助。

Qt解决方案不是必需的。这更像是一个学术问题,因为我的解决方法适用于我目前的情况。

4

1 回答 1

6

std::shared_ptr(或者boost::shared_ptr如果你没有 C++11)有一个构造函数,它接受一个共享指针r和一个指针p。构造的共享指针将指向*p,但与共享所有权r。这应该是你需要的。

构造函数的签名是

template<class Y> shared_ptr(const shared_ptr<Y>& r, T *p) noexcept;
于 2012-12-11T16:45:39.350 回答