[英]Overload Resolution with g++
I am working on implementing a serialization class, Serializable
. 我正在实现序列化类
Serializable
。 This class has the following method signatures: 此类具有以下方法签名:
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);
I have a derived class Baz
and another derived class Bar
. 我有一个
Baz
派生类和另一个Bar
派生类。 Bar
has a member variable Baz* baz;
Bar
有一个成员变量Baz* baz;
. 。
Bar
has the following methods: Bar
具有以下方法:
void deserialize(Buffer& buffer) {
deserializeMember(buffer, baz);
}
void serialize(Buffer& buffer) const {
serializeMember(buffer, baz);
}
When I execute my code, the call to serialize resolves to the serializeMember
overload with int
as the second parameter. 当我执行代码时,对序列化的调用将解析为
serializeMember
重载,并将int
作为第二个参数。 Same as if I make that a template function, similar to deserializeMember
. 就像我使该模板函数一样,类似于
deserializeMember
。 The call to deseralizeMember
resolves correctly. 对
deseralizeMember
的调用可以正确解决。
Why doesn't my Serializable
pointer resolve to the correct overloaded method? 为什么我的
Serializable
指针不能解析为正确的重载方法?
The correct signature is: 正确的签名是:
void serializeMember(Buffer& sb, const Serializable* const& member) const;
Since serializeMember
is a const method of Bar
, and baz
is a pointer beloning to Bar
, we need to either pass the const pointer by value or pass the const pointer as a const reference. 由于
serializeMember
是Bar
的const方法,而baz
是属于Bar
的指针,我们需要按值传递const指针,或将const指针作为const引用传递。 Hence, const Serializable* const&
. 因此,
const Serializable* const&
。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.