简体   繁体   English

g ++的过载解析

[英]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. 由于serializeMemberBar的const方法,而baz是属于Bar的指针,我们需要按值传递const指针,或将const指针作为const引用传递。 Hence, const Serializable* const& . 因此, const Serializable* const&

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM