重载解析与g++
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&
.
相关文章:
- 继承函数的重载解析
- 你能重载对象变量名本身返回的内容吗
- 从父命名空间重载类型
- 使用C++中的模板和运算符重载执行矩阵运算
- 为什么这个运算符<重载函数对 STL 算法不可见?
- 重载操作程序时出错>>用于类中的字符串 memebr
- 一个关于在C++中重载布尔运算符的问题
- 不同翻译单元中不可重载的非内联函数定义
- 为什么使用SFINAE而不是函数重载
- 为什么我不能在 C++ 中的特定函数重载中调用同一函数的任何其他重载?
- 将重载的成员函数传递给函数模板
- c++:可变模板和函数重载
- 重载元组索引运算符-C++
- 如何使用重载的相等(==)运算符向测试用例添加描述
- 重载==不适用于二进制树
- 为什么Mat类的两个对象可以在不重载运算符+的情况下添加
- 重载运算符new[]的行为取决于析构函数
- 正在尝试重载二进制搜索树分配运算符
- 重载Singly Linked List中的赋值运算符
- 取消引用运算符不能重载