使用Qt的容器时总是让人省心,不仅是它同时提供了C++ Style和Java Style的操作接口,并且还支持下面这样的连续赋值方式:
QVector<int> vec; vec << 7 << 3 << 9 << 3 << 2 << 1 << 6 << 8;
不过好在,我们可以用装饰类为std::vector添加这个功能,下面我们先实现一个简单的“Vector装饰者”:
template<typename T> class VectorDecorator { public: VectorDecorator(std::vector<T>& in) : m_vec(in) {} inline VectorDecorator& operator<< (const T &t) { m_vec.push_back(t); return *this; } private: std::vector<T>& m_vec; };
然后重载 operator<<,调用push_back实际添加数据,返回自身以继续接受之后的"<<"。
这个装饰者使用起来也很方便,使用VectorDecorator<int>(vec)的方式就可以让 vec 临时获取支持连续赋值的能力。写段测试代码看看:
vector<int> pre; VectorDecorator<int>(pre) << 7 << 3 << 9 << 3 << 2 << 1 << 6 << 8; for ( size_t i = 0; i < pre.size(); ++i ) { cout << pre.at(i) << " "; } cout << endl;
template<typename T> class VectorDecorator { public: VectorDecorator(std::vector<T>& in) : m_vec(in) {} inline VectorDecorator& operator<< (const T &t) { m_vec.push_back(t); return *this; } inline VectorDecorator& operator<< (const std::vector<T> &l) { m_vec.insert(m_vec.end(), l.begin(), l.end()); return *this; } private: std::vector<T>& m_vec; };
vector<int> pre; vector<int> in; VectorDecorator<int>(pre) << 7 << 4 << 9 << 3 << 2 << 1 << 6 << 8; VectorDecorator<int>(in) << 10 << 12 << pre << 16 << 18; for ( size_t i = 0; i < in.size(); ++i ) { cout << in.at(i) << " "; } cout << endl;