[英]Overload Resolution with g++
我正在实现序列化类Serializable
。 此类具有以下方法签名:
void serializeMember(Buffer& sb, const Serializable*& member) const;
void serializeMember(Buffer& sb, const int& member) const;
template<typename T>
void deserializeMember(Buffer& sb, T*& member);
我有一个Baz
派生类和另一个Bar
派生类。 Bar
有一个成员变量Baz* baz;
。 Bar
具有以下方法:
void deserialize(Buffer& buffer) {
deserializeMember(buffer, baz);
}
void serialize(Buffer& buffer) const {
serializeMember(buffer, baz);
}
当我执行代码时,对序列化的调用将解析为serializeMember
重载,并将int
作为第二个参数。 就像我使该模板函数一样,类似于deserializeMember
。 对deseralizeMember
的调用可以正确解决。
为什么我的Serializable
指针不能解析为正确的重载方法?
正确的签名是:
void serializeMember(Buffer& sb, const Serializable* const& member) const;
由于serializeMember
是Bar
的const方法,而baz
是属于Bar
的指针,我们需要按值传递const指针,或将const指针作为const引用传递。 因此, const Serializable* const&
。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.