我在 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)? ;-)

10-07 16:27