我有一个模板化的Stack类,内部用vector实现。
以下是我(简化)TStack.h的内容:
#include <vector>
#include <iostream>
template<typename T> class TStack;
template<typename T> TStack<T> operator+(const TStack<T> &s1, const TStack<T> &s2);
template<typename T>
class TStack {
friend TStack<T> operator+<>(const TStack<T> &s1, const TStack<T> &s2);
private:
std::vector<T> items;
public:
void printAll() {
std::cout << "The content of the stack is: ";
typename std::vector<T>::iterator it;
for(it = items.begin(); it < items.end(); it++) {
std::cout << *it << " ";
}
std::cout << std::endl;
}
};
template<typename T>
TStack<T> operator+(const TStack<T> &s1, const TStack<T> &s2) {
TStack<T> result = s1;
typename std::vector<T>::iterator it;
//below is line 41
for(it = s2.items.begin(); it < s2.items.end(); it++) {
result.items.push_back(*it);
}
return result;
}
这是我的(简化)主要课程:
#include <iostream>
#include "TStack.h"
using namespace std;
int main(int argc, char *argv[]) {
TStack<int> intStack;
intStack.push(4);
TStack<int> secondIntStack;
secondIntStack.push(10);
cout << "Addition result: " << endl;
//below is line 27
TStack<int> result = intStack + secondIntStack;
result.printAll();
return 0;
}
这是编译结果:
In file included from main.cpp:2:
TStack.h: In function ‘TStack<T> operator+(const TStack<T>&, const TStack<T>&) [with T = int]’:
main.cpp:27: instantiated from here
TStack.h:41: error: no match for ‘operator=’ in ‘it = s2->TStack<int>::items.std::vector<_Tp, _Alloc>::begin [with _Tp = int, _Alloc = std::allocator<int>]()’
/usr/include/c++/4.4/bits/stl_iterator.h:669: note: candidates are: __gnu_cxx::__normal_iterator<int*, std::vector<int, std::allocator<int> > >& __gnu_cxx::__normal_iterator<int*, std::vector<int, std::allocator<int> > >::operator=(const __gnu_cxx::__normal_iterator<int*, std::vector<int, std::allocator<int> > >&)
make: *** [main.exe] Error 1
我不知道错误信息的含义是什么。
在operator +函数中,我使用相同的方法在printAll()中获取迭代器,但它在operator +函数内部无法正常工作。 我知道我可以避免在operator +函数中使用迭代器,但我只是想知道如何修复它。
答案 0 :(得分:5)
使用const_iterator
代替iterator
:
typename std::vector<T>::const_iterator it;
因为s1
是一个const对象。所以s1.items
也将是const对象,这意味着s1.items.begin()
将返回const_iterator
,而不是非const iterator
。
更好地实施operator +()
您可以改进operator+()
的实施。您可以使用push_back
函数作为:
insert
函数。
template<typename T>
TStack<T> operator+(const TStack<T> &s1, const TStack<T> &s2) {
TStack<T> result(s1); //use direct copy-initialization
result.insert(result.end(), s2.begin(), s2.end());
return result;
}
完全避免了您在代码中遇到iterator
的问题。
更好地实施operator +()
如果按值接受第一个参数,而不是const引用,那就更好了:
template<typename T>
TStack<T> operator+(TStack<T> s1, const TStack<T> &s2) {
s1.insert(s1.end(), s2.begin(), s2.end()); //s1 is a copy, after all!
return s1;
}
由于第一个参数是 copy 本身,因此您无需显式创建名为result
的局部变量。您只需将s2
添加到s1
并返回s1
。
答案 1 :(得分:3)
您不能将const迭代器(s2.items.begin()
)分配给非常量迭代器。
使用
typename std::vector<T>::const_iterator it;