На этом шаге мы приведем типичную реализацию класса stack.
Интерфейс класса stack<> настолько компактен, что в нем можно легко разобраться, проанализировав типичную реализацию:
namespace std {
template <class T, class Container = deque<T> >
class stack {
public:
typedef typename Container::value_type value_type;
typedef typename Container::size_type size_type;
typedef Container container_type;
protected:
Container c; // Контейнер
public:
explicit stack(const Container& = Container());
bool empty() const { return c.empty(); }
size_type size() const { return c.size(); }
void push(const value_type& x) { c.push_back(x); }
void pop() { c.pop_back(); }
value_type& top() { return c.back(); }
const value_type& top() const { return c.back(); }
};
template <class T, class Container>
bool operator==(const stack<T, Container>&,
const stack<T, Container>&);
template <class T, class Container>
bool operator< (const stack<T, Container>&,
const stack<T, Container>&);
... // (Другие операторы сравнения)
}
В следующих шагах приводятся более подробные описания членов класса stack<>.
Со следующего шага мы более подробно рассмотрим приведенную реализацию класса stack.