转换运算符重载
Conversion operator overloading
我想区分 &、* 和值之间的模板转换运算符:
struct S
{
template <class T>
constexpr operator T()
{
return value;
}
template <class T>
constexpr operator T&()
{
return value;
}
template <class T>
constexpr operator T*()
{
return &value;
}
int value;
} s{5};
int main()
{
uint32_t ui = s; // error: error C2440: 'initializing': cannot convert from 'S' to 'uint32_t
}
如果我删除constexpr operator T&()
代码将编译并ui = s
调用constexpr operator T()
运算符。但是为什么?
当我向这些函数添加显式说明符时,我也会出现奇怪的行为。
看起来转换运算符的行为与正常重载不同。谁能解释一下?
PS:我正在使用VS2017
由于value
的类型是 int
,因此创建模板转换为模板参数引用类型没有意义。如果类型不是 int
,则会出现试图将int
对象强制引用到某种其他类型的引用的语义错误。
将引用转换重新定义为正确的类型:
constexpr operator int&()
{
return value;
}
constexpr operator const int&() const
{
return value;
}
相关文章:
- 为什么Mat类的两个对象可以在不重载运算符+的情况下添加
- 重载运算符new[]的行为取决于析构函数
- 为什么将值返回函数传递给重载=运算符对运算符函数有效,而对其他运算符无效
- 在 myVector 类中重载运算符 + 时出错
- 为什么常量词在重载运算符中不与 ostream 对象一起使用<<?
- 如何在 cpp 中重载运算符 +=?
- C++ 如何重载 [] 运算符并进行函数调用
- 重载运算符的范围是什么?它是否会影响作为类成员的集合的插入函数?
- 为什么我可以在不重载 "=" 运算符的情况下将一个对象分配给另一个对象?
- 重载运算符有地址吗?
- 如何迭代重载运算符 [] 的类?
- 重载运算符与添加问题
- 模板基类中的重载运算符
- 如何调用用于重载运算符"<<"的 friend 函数?
- 在 C++17 中的命名空间和子命名空间中重载运算符是不明确的
- 重载运算符<<采用谷歌 C++ 风格
- C++ 如何正确重载 + 运算符
- cout (<<) 重载运算符不打印减去的矩阵
- 如何在 c++ 中重载运算符 + 以便能够 whrite c_str = "smth" + c_str;
- 重载运算符*以获取对另一个类的实例的引用