重载模板类中的运算符=
Overloading operator= in templated class
我正在学习模板,偶然发现了这个问题:
template <typename T, typename CONT>
class someContainer {
public:
someContainer (const std::initializer_list<T>& ini) {
for (const auto& elem : ini) {
m_cont.push_back(elem);
}
}
template <typename DST_CONT>
someContainer& operator=(const DST_CONT& cont) {
m_cont.clear();
for (const auto& elem : cont.m_cont) {
m_cont.push_back(static_cast<T>(elem));
}
return *this;
}
private:
CONT m_cont;
}
如果我这样称呼这个类:
someContainer <int, std::vector<int>> ivec{ 1,2 };
someContainer <int, std::vector<int>> ivec2{ 1,2,3 };
ivec = ivec2;
此处m_cont将由1,2,3 正确分配正确的值
但是,如果我这样做:
someContainer <int, std::vector<int>> ivec{ 1,2 };
someContainer <int, std::deque<int>> ivec2{ 1,2,3 };
ivec = ivec2;
分配操作将失败:
cannot access private member declared in class 'someContainer<int,std::deque<int,std::allocator<_Ty>>>'
在这种情况下,如何实现重载运算符=,例如,将模板int,std::vector分配给float,std:::deque?
编译器是MSVC2015
尝试将函数设为friend,但在friend函数中不可能返回*this。
尝试使此函数成为非成员-MSVC告诉我不能使operator=非成员
首先,不要只为任何事情重载赋值,而只为同一模板的其他专业化重载赋值。第二,使所有专业化相互friend
:
template <typename T>
class X
{
T m_;
template <typename> friend class X; // all specializations of X are friends
public:
template <typename U>
X & operator=(const X<U> & rhs) // assign from any specialization of X
{
m_ = rhs.m_;
return *this;
}
};
相关文章:
- 使用C++中的模板和运算符重载执行矩阵运算
- 为什么这个运算符<重载函数对 STL 算法不可见?
- <T> 通过模板化运算符重载将 std::complex 乘以双倍
- C++20概念:需要运算符重载
- 使用赋值运算符重载从类中返回jobject
- 在运算符重载定义中使用成员函数(const错误)
- 字节到位运算符重载C++
- 为什么在运算符重载时需要参考?
- 类中 c++ 的运算符 + 重载
- 算术复合运算符重载为非成员
- 运算符重载 (+),用于添加两个具有 C++ 的数组
- 交换运算符 + 重载会导致无限递归
- 如何理解新的运算符重载?
- 向量保持复数的运算符重载
- 如何创建运算符重载?
- 链接列表运算符重载没有打印出我想要的内容
- C++:需要帮助了解运算符重载错误
- 使用模板化运算符重载 XOR 运算符失败
- 如何确保接受的C++模板类型使运算符重载?
- 运算符重载使用运算符+添加类模板