nested.cpp

来自「Think in C++ 2nd」· C++ 代码 · 共 46 行

CPP
46
字号
//: C04:Nested.cpp {O}

// From Thinking in C++, 2nd Edition

// Available at http://www.BruceEckel.com

// (c) Bruce Eckel 1999

// Copyright notice in Copyright.txt

// Linked list with nesting

#include "Stack.h"

#include "../require.h"

using namespace std;



void 

Stack::Link::initialize(void* dat, Link* nxt) {

  data = dat;

  next = nxt;

}



void Stack::initialize() { head = 0; }



void Stack::push(void* dat) {

  Link* newLink = new Link();

  newLink->initialize(dat, head);

  head = newLink;

}



void* Stack::peek() { return head->data; }



void* Stack::pop() {

  if(head == 0) return 0;

  void* result = head->data;

  Link* oldHead = head;

  head = head->next;

  delete oldHead;

  return result;

}



void Stack::cleanup() {

  Link* cursor = head;

  while(head) {

    cursor = cursor->next;

    delete head->data; // Assumes a 'new'!

    delete head;

    head = cursor;

  }

  head = 0; // Officially empty

} ///:~

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?