c++ - 双向链表节点的下一个是私有(private)的

标签 c++ doubly-linked-list

我正在实现一个双向链表,并使用我自己的对象作为存储的数据。

这是我的对象:

#ifndef PLAY_H_INCLUDED
#define PLAY_H_INCLUDED
#include <string>

class Play
{
private:
    int m_quarter;
    int m_minutes;
    std::string oTeam;
    std::string dTeam;
    int m_down;
    int m_yardToGO;
    int m_startLoc;
    int playDesc;
    std::string wholePlay;
    int relevance;
    int relCounter;
public:
    int getQuarter();
    int getMinutes();
    std::string getoTeam();
    std::string getdTeam();
    int getDown();
    int getYard();
    int getStartLoc();
    int getPlayDesc();
    std::string getwholePlay();
    Play(int quarter, int minutes, std::string offense, std::string defense, int dwn, int ytg, int start, int desc, std::string play, int relevance, int relCounter);
    ~Play();
    Play parse(std::string toParse);
    std::string findPlay(std::string playDesc);
};

#endif // PLAY_H_INCLUDED

-

这是我的节点:

template<class T>
class node{
    friend class Play;
    T data;
    node *next, *prev;
    node(const T& t, node *n = 0, node *p = 0) {data=t; next=n; prev=p;}
};

我得到的确切错误是:

error: node<Play>* node<Play>::next is private.

我假设我遇到这个问题是因为 Play 的信息是私有(private)的并且节点无法访问,为了解决这个问题,我尝试让节点成为 Play 的友元类。当我这样做时,我收到错误提示“node is not a template type”。该错误对我来说毫无意义,因此我认为这不是解决问题的方法。

谢谢。

最佳答案

使用 public: 以上属性应该是公开的。如果您不指定任何内容,所有内容都会变为私有(private)。

template<class T>
class node{
    public: // ADD THIS
    friend class Play;
    T data;
    node<T> *next, *prev;
    node(const T& t, node<T> *n = 0, node<T> *p = 0) { // EDIT

        data=t; next=n; prev=p;
    }
};

编辑:在使用模板类时,你总是需要使用 <>,就像我在上面编辑的那样。

关于c++ - 双向链表节点的下一个是私有(private)的,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19399451/

相关文章:

c++ - 静态模板类的建议

c++ - 如何在 C++ 中解析枚举?

java - 双向链表的输出为空

java - 在java中实现能够处理数组列表、链表和双向链表的SelectionSort

c - 初始化静态大小的全局 malloc()

c++ - 该程序不能在 DOS 模式下运行

c++ - 使用 CMAKE 单独进行 CUDA 编译

c++ - 项目结构问题

c++ - 使用 const 指针打印双链表

c++ - 指针和双向链表