模板结构的 C++ 运算符重载
c++ operator-overloading for a template struct
我有一个模板结构"点如下:
template<typename T>
struct point
{
T x, y, z;
template<typename T1>
inline point<T> operator*(const point<T1>& p) const // multiply by another point.
{
return point<T>{this->x*p.x, this->y*p.y, this->z*p.z};
}
template<typename T1>
inline point<T> operator*(const T1& v) const // multiply by constant from right side
{
return point<T>{this->x*v, this->y*v, this->z*v};
}
}
template<typename T1, typename T2>
inline point<T1> operator*(const T2& v, const point<T1>& p) // multiply by a constant from the left side.
{
return point<T1>{p.x*v, p.y*v, p.z*v};
}
声明为成员函数的两个运算符重载函数,第一个应该乘以另一个点,另一个将一个点乘以右侧的常量,其中在结构外部声明的运算符重载函数是做同样的事情,但从左侧。
现在,当我去编译以下代码时:
point<double> p1{1,2,3};
point<float> p2{1,2,3};
point<double> p3 = p1*p3;
编译器调用在结构外部声明的那个,而不是声明为成员函数的那个,并产生和错误:
error: cannot convert ‘point<double>’ to ‘float’ in initialization
return point<T1>{p.x*v, p.y*v, p.z*v};
这是有道理的,因为这两个参数都是模板变量,可以解释为点变量。现在第二个只能是一个点变量,但第一个可以是任何东西!
为了解决这个问题,我可以去编写该函数的几个副本,当将第一个参数声明为 int、float、double、long double .. 等时。这对我来说很好用,但我仍然想知道是否有更好的方法来解决这个问题,如果我只能像上面那样写一个副本?
不要不必要地将运算符重载为成员函数, 请遵循此处所述的规则。
在我看来,operator*
两个point
实例返回左侧实例的类型是没有意义的。在返回类型的推导中,最好考虑这两种类型,因为该函数被定义为可交换的。
template<typename T>
struct point
{
T x, y;
};
template<typename T1, typename T2>
auto operator*(const point<T1>& lhs, const point<T2>& rhs)
-> point<decltype(std::declval<T1>() * std::declval<T2>())>
{
return {lhs.x*rhs.x, lhs.y*rhs.y};
}
template<typename T1, typename T2>
point<T1> operator*(const point<T1>& p, const T2& v)
{
return {p.x*v, p.y*v};
}
template<typename T1, typename T2>
point<T1> operator*(const T2& v, const point<T1>& p)
{
return p * v;
}
尝试对重载执行相同的操作,以乘以标量作为练习。
相关文章:
- 使用C++中的模板和运算符重载执行矩阵运算
- 为什么这个运算符<重载函数对 STL 算法不可见?
- <T> 通过模板化运算符重载将 std::complex 乘以双倍
- C++20概念:需要运算符重载
- 使用赋值运算符重载从类中返回jobject
- 在运算符重载定义中使用成员函数(const错误)
- 字节到位运算符重载C++
- 为什么在运算符重载时需要参考?
- 类中 c++ 的运算符 + 重载
- 算术复合运算符重载为非成员
- 运算符重载 (+),用于添加两个具有 C++ 的数组
- 交换运算符 + 重载会导致无限递归
- 如何理解新的运算符重载?
- 向量保持复数的运算符重载
- 如何创建运算符重载?
- 链接列表运算符重载没有打印出我想要的内容
- C++:需要帮助了解运算符重载错误
- 使用模板化运算符重载 XOR 运算符失败
- 如何确保接受的C++模板类型使运算符重载?
- 运算符重载使用运算符+添加类模板