基于命名空间类型和primitif类型的成员函数重载
Member function overload based on namespaced typedefed primitif types
以下代码在C++03和C++11 中都无法使用g++4.8进行编译
namespace N {typedef int A;}
namespace NN {typedef int A;}
struct Z
{
void foo(N::A){}
void foo(NN::A){}
};
错误为
d.cpp:7:10: erreur: ‘void Z::foo(NN::A)’ cannot be overloaded
void foo(NN::A){}};
^
d.cpp:6:6: erreur: with ‘void Z::foo(N::A)’
void foo(N::A){}
我一直认为不同名称空间中的类型是不同的类型,不管怎样。但事实似乎并非如此。我觉得编译器在最后摆脱了名称空间/typedef,专注于底层类型,结果发生了冲突。
我说得对吗?你有变通办法吗?
类型不存在于名称空间中Names确实如此。你重载的是类型,而不是名称。
typedef
只是同一类型的另一个名称。只能在不同类型上重载。
相关文章:
- 访问C++中的类型成员
- 具有 STL 向量类型成员的类的复制内存
- 重载具有 2 个相同数据类型成员的构造函数
- std::void_t 和嵌套的非类型成员
- 返回对常量结构(指针类型)成员的引用:明显的左值到右值转换
- 使用各种数据类型成员创建对象的简便方法
- 将类类型成员定义为公共和私有之间有什么区别?
- 结构类型成员的默认构造函数中的默认参数
- 如何传递模板模板非类型成员函数指针
- 文本类类型成员函数约束
- 给定仅包含布尔类型成员的结构的两个对象 s1 和 s2,只要 s1 的成员为 true,请检查 s2 的每个成员是否为真
- 如何在 c++ 中使用二进制文件输入/输出读取/写入结构的字符串类型成员
- C++:将模板参数的模板类型成员加为好友的语法正确吗
- C++静态结构类型成员初始化
- C++:作为引用或指针的基类型成员变量
- 左值引用类型成员的用户定义移动构造函数
- 具有指针类型成员的类在 MSVS2012@debug 下销毁时失败.程序错误或错误源
- CRTP -- 访问不完整的类型成员
- 为什么C++默认初始化不对非类类型成员进行零初始化
- 请求非类类型成员