我想通过使用链表来实现一个堆栈类。这是我在头文件中定义的方式。对于堆栈中的每个元素,元素中有两个数据:
#ifndef MYSTACK_H_INCLUDED
#define MYSTACK_H_INCLUDED
#include <iostream>
using namespace std;
template<typename T>
class MyStack{
public:
MyStack();
~MyStack();
...
...
private:
struct node;
node* head;
int _top;
};
template<typename T>
struct MyStack<T>::node {
node(node*, T, T);
T position_x;
T position_y;
node* next;
};
但是,如果我将私有字段中的结构节点更改为这样的类怎么办:
#ifndef MYSTACK_H_INCLUDED
#define MYSTACK_H_INCLUDED
#include <cstddef> // for std:size_t
using namespace std;
template <class T>
class MyStack{
public:
MyStack();
~MyStack();
...
...
private:
class Node {
friend class MyStack<T>;
public:
Node(T, Node*);
private:
const T value;
Node *next;
};
Node *head;
};
#endif // MYSTACK_H_INCLUDED
是否有必要在 Stack 类中为 Node 创建另一个类,或者我只使用 Struct ?为什么?