我有以下类CppProperty类,它包含值:
template<typename TT>
class CppProperty
{
TT val;
public:
CppProperty(void)
{
}
CppProperty(TT aval) : val(aval)
{
}
CppProperty(const CppProperty & rhs)
{
this->val = rhs.val;
}
virtual ~CppProperty(void)
{
}
TT operator=(TT aval)
{
this->val = aval;
return this->val;
}
friend TT operator++(CppProperty & rhs);
friend TT operator--(CppProperty & rhs);
friend TT operator++(CppProperty & rhs, int);
friend TT operator--(CppProperty & rhs, int);
//template<typename RR>
//friend RR operator=(RR & lhs, const CppProperty & rhs);
//friend int & operator=(int & lhs, const CppProperty & rhs);
//int reinterpret_cast<int>(const CppProperty & rhs);
};
我想做这样的任务:
CppProperty<char> myproperty(10);
myproperty++;
int count = myproperty;
如何做到这一点?我无法覆盖operator =。任何帮助是极大的赞赏!谢谢!
答案 0 :(得分:5)
您需要转换运算符:
operator const TT&(void) const
{
return val;
}
operator TT&(void)
{
return val;
}
有关转化运算符here的简要教程。简而言之,当编译器尝试转换类型时,它将首先查看将其转换为所需类型的运算符的右侧。我们正在做的是说“无论TT
是什么,这个类可以转换为它”。
如果没有找到操作符,它会查看是否可以从右侧构建左侧,依此类推。 (直到,如果它找不到转换,它会发出错误。)
如果您声明其他构造函数,则可以删除显式定义的默认构造函数:
// If not specified, construct with default-constructed type.
CppProperty(TT aval = TT()) : val(aval)
{
}
答案 1 :(得分:1)
您需要向您的类提供operator int()
以允许隐式转换为int。
答案 2 :(得分:1)