我在 namespace MYLIB中有一个称为OrderedList的类。在其中,我有一个称为iterator的嵌套类,它将用作OrderedList类的迭代器。
以下是我创建OrderedList和Iterator类的代码段:
template<class T>
class OrderedList
{
private:
ListNode<T>* head;
ListNode<T>* tail;
int total;
public:
OrderedList(T[],int);
~OrderedList();
void insert(const T&);
void sort(int);
void output();
class iterator
{
private:
ListNode<T>* curr;
int current;
OrderedList& order;
public:
iterator(OrderedList& ord, bool is_end)
{
this->order = ord; //problem is here
if(is_end == false)
{...
我主要功能的代码段:
int main()
{
int one[5] = {9,7,5,4,1};
MYLIB::OrderedList<int> odd(one,5);
odd.output();
MYLIB::OrderedList<int>::iterator starter(odd,false);
编译时,出现以下错误:
OrderedList.cpp: In instantiation of ‘MYLIB::OrderedList<T>::iterator::iterator(MYLIB::OrderedList<T>&, bool) [with T = int]’:
OrderedList.cpp:215:53: required from here
OrderedList.cpp:47:6: error: uninitialized reference member ‘MYLIB::OrderedList<int>::iterator::order’ [-fpermissive]
iterator(OrderedList& ord, bool is_end)
^
最佳答案
在C++中,必须在成员初始化列表中初始化引用,但不能在coustructor主体中初始化引用。
您需要将代码更改为
iterator(OrderList& ord, bool is_end) : order(ord) {
if (is_end == false) {
...
}
}
而不是使用分配。
对引用的赋值会做不同的事情(它为引用所引用的原始对象赋值)。您无法更改引用绑定(bind)的内容。
PS:为什么停在那里,而不要使用
if ((is_end == false) == true)
? ;-)