Невозможно получить доступ к базовым защищенным членам в производном классе! (в виртуальных функциях) - PullRequest
0 голосов
/ 10 апреля 2019

У меня есть абстрактный класс, например A (несколько чисто виртуальных функций). Я публично унаследовал класс B от класса A. Предоставляя определения виртуальных функций, я пытаюсь получить доступ к закрытым членам класса A (например, Ptr). Однако компилятор не может найти объявление всех защищенных членов класса A. Что здесь не так?

        //
        // LinkedListType.h
        //

        #ifndef LINKEDLISTTYPE_LINKEDLISTTYPE_H
        #define LINKEDLISTTYPE_LINKEDLISTTYPE_H

        #include <iostream>
        using namespace std;

        template <class Type>
        struct nodeType
        {
            int val;
            nodeType<Type> *link;
        };

        template <class Type>
        class LinkedListType{
        public:

            virtual void insertFirst(Type& node)=0;

            LinkedListType();
            ~LinkedListType();
            void destroyList();
        protected:
            int count;
            nodeType<Type> *first;
            nodeType<Type> *last;
        };
        #endif //LINKEDLISTTYPE_LINKEDLISTTYPE_H


        //
        // LinkedListType.cpp
        //
        #include <iostream>
        #include "LinkedListType.h"

        using namespace std;

        template <class Type>
        void LinkedListType<Type>::destroyList() {
            if (firstElem == NULL)cout<<"LinkedList is empty"<<endl;

            nodeType<Type> *tmp;
            while(tmp != NULL){
                tmp=first;
                first=first->link;
                delete tmp;
            }
            last=NULL;
            count =0;
        }



        template <class Type>
        LinkedListType<Type>::LinkedListType() {
            first=NULL;
            last=NULL;
            count=0;
        }


        template <class Type>
        LinkedListType<Type>::~LinkedListType() {
            destroyList();
        }




//
        // unorderedLinkedList.cpp
        //

        #ifndef UNORDEREDLINKEDLIST_UNORDEREDLINKEDLIST_H
        #define UNORDEREDLINKEDLIST_UNORDEREDLINKEDLIST_H

        #include <iostream>
        #include "LinkedListType.h"

        using namespace std;

        template <class Type>
        class unorderedLinkedList: public LinkedListType<Type>{
        public:
            void insertFirst(Type& node);
        };
        #endif //UNORDEREDLINKEDLIST_UNORDEREDLINKEDLIST_H



        //
        // unorderedLinkedList.h
        //
        #include <iostream>
        #include "unorderedLinkedList.h"

        using  namespace std;

        template <class Type>
        void unorderedLinkedList<Type>::insertFirst(Type& node) {
            nodeType<Type> *newNode= new nodeType<Type>;
            if(newNode == NULL)
                assert("Unable to allocate node to insert");
            newNode->val=node;
            newNode->link=first;  /* ---> ERROR error: use of undeclared 
                               identifier 'first'; did you mean 
                               'std::_PairT::first'? */
            first=newNode; /* ---> ERROR error: use of undeclared 
                                identifier 'first'; did you mean 
                               'std::_PairT::first'? */
            count++;
        }



        //
        // CMakeList.txt
        //
        cmake_minimum_required(VERSION 3.13)
        project(UnorderedLinkedList)

        set(CMAKE_CXX_STANDARD 14)

        add_executable(UnorderedLinkedList main.cpp LinkedListType.h LinkedListType.cpp unorderedLinkedList.h unorderedLinkedList.cpp)


        //Main program
        #include <iostream>
        #include "unorderedLinkedList.h"
        #include "unorderedLinkedList.cpp"
        using namespace std;

        int main() {
            std::cout << "Hello, World!" << std::endl;
            unorderedLinkedList<int> u1;
            u1.insertFirst(10);
            return 0;
        }

1 Ответ

0 голосов
/ 13 апреля 2019

Все частные члены должны были сослаться с шаблоном определения родителя.например, first изменится на connectedListType :: first;

Это связано с некоторыми ограничениями компилятора для использования библиотеки шаблонов.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...