使用模板重载运算符
Overloading Operators with templates
因此,在使用模板时,我遇到了重载赋值运算符的问题。基本上,我采用了一个自定义的可调整大小的数组类,它由另一个缺乏调整大小能力的数组类继承。不管怎样,我有两个相等运算符,一个用于处理相同大小的数组,另一个用于在类型相同的情况下处理不同大小的数组。
这是操作员的代码:
// operator =
//
template <typename T, size_t N>
const Fixed_Array <T, N> & Fixed_Array <T, N>::operator = (const Fixed_Array <T, N> & rhs)
{
for(size_t x = 0; x < N; x++)
{
this->set(x, rhs[x]);
}
return *this;
}
//
// operator =
//
template <typename T, size_t N>
template <size_t M>
const Fixed_Array <T, N> & Fixed_Array <T, N>::operator = (const Fixed_Array <T, M> & rhs)
{
this->resize(M);
for(size_t x = 0; x < M; x++)
{
this->set(x, rhs[x]);
}
return *this;
}
下面是我用来创建和分配的:
Fixed_Array<char, 10> * fa1 = new Fixed_Array<char, 10>();
Fixed_Array<char, 20> * fa2 = new Fixed_Array<char, 20>();
fa1 = fa1; //works
fa1 = fa2; //causes compiler to freak out
错误信息基本上是说我不能用10和20来做这件事;它并没有用模板提取我的第二个赋值运算符。
有什么建议吗?
您分配的是指针,而不是对象(导致内存泄漏是副作用!)。指针是不同类型的(<char,10>
和<char,20>
),所以编译器会抱怨它
您的operator =
签名似乎是正确的,分配的语法应该是:
*fa1 = *fa2; // ok (no memory leak)
如何在一个应该具有固定大小的类上调用resize
?这不会破坏东西吗?
例如,
Fixed_Array<char, 10> little1;
Fixed_Array<char, 20> big1, big2;
big1 = little1;
/* now big1 has size 10, because it was resized */
big1 = big2; /* tries to store 20 elements into a buffer of size 10 */
这将损坏堆(从形式上讲,这是未定义的行为)。
相关文章:
- 为什么Mat类的两个对象可以在不重载运算符+的情况下添加
- 重载运算符new[]的行为取决于析构函数
- 为什么将值返回函数传递给重载=运算符对运算符函数有效,而对其他运算符无效
- 在 myVector 类中重载运算符 + 时出错
- 为什么常量词在重载运算符中不与 ostream 对象一起使用<<?
- 如何在 cpp 中重载运算符 +=?
- C++ 如何重载 [] 运算符并进行函数调用
- 重载运算符的范围是什么?它是否会影响作为类成员的集合的插入函数?
- 为什么我可以在不重载 "=" 运算符的情况下将一个对象分配给另一个对象?
- 重载运算符有地址吗?
- 如何迭代重载运算符 [] 的类?
- 重载运算符与添加问题
- 模板基类中的重载运算符
- 如何调用用于重载运算符"<<"的 friend 函数?
- 在 C++17 中的命名空间和子命名空间中重载运算符是不明确的
- 重载运算符<<采用谷歌 C++ 风格
- C++ 如何正确重载 + 运算符
- cout (<<) 重载运算符不打印减去的矩阵
- 如何在 c++ 中重载运算符 + 以便能够 whrite c_str = "smth" + c_str;
- 重载运算符*以获取对另一个类的实例的引用