0

我正在尝试调查 MsgPack 的源代码。在示例中有一个片段:

std::vector<std::string> vec;    
vec.push_back("MessagePack");
msgpack::sbuffer sbuf;
msgpack::pack(sbuf, vec);

我在 /usr/include/msgpack/object.hpp 中看到要打包的对象必须具有方法 msgpack_pack:

template <typename Stream, typename T>
inline packer<Stream>& operator<< (packer<Stream>& o, const T& v)
{
    return detail::packer_serializer<Stream, T>::pack(o, v);
}

namespace detail {
template <typename Stream, typename T>
struct packer_serializer {
        static packer<Stream>& pack(packer<Stream>& o, const T& v) {
                v.msgpack_pack(o);
                return o;
        }
};
}

所以我不明白编译器如何允许将 std::vector 传递给 msgpack::pack。

4

1 回答 1

0

MessagePack 包括对 STL 的内置支持。

如您所见src/msgpack/type/vector.hpp,实现了<<a 的运算符std::vector

template <typename Stream, typename T>
inline packer<Stream>& operator<< (packer<Stream>& o, const std::vector<T>& v)
{
    o.pack_array(v.size());
    for(typename std::vector<T>::const_iterator it(v.begin()), it_end(v.end());
            it != it_end; ++it) {
        o.pack(*it);
    }
    return o;
}

src/msgpack/type/string.hpp为 a 实现相同的运算符std::string

template <typename Stream>
inline packer<Stream>& operator<< (packer<Stream>& o, const std::string& v)
{
    o.pack_raw(v.size());
    o.pack_raw_body(v.data(), v.size());
    return o;
}

因此打包一个std::vector<std::string>.

于 2014-07-30T08:20:43.133 回答