我的Stack實現(用C++實現),模仿STL的Stack實現,但是不用容器類

來源:互聯網
上載者:User

STL的函數參數類型很規範而且很有效率,舉個例子說明

const T& getTop() const

cosnt T&指的是getTop()返回的是引用,減少一次值返回構造的臨時對象,但是這個對象又是不可更改的(和T &operator=()對比),同時這是一個const函數,表示不會修改類的成員變數!


具體的實現代碼:

class Stack

{

public:

Stack():max_size(init_size)
{
top=base=(T*)malloc(sizeof(T)*init_size);

}

~Stack()
{
delete base;

}

void pushStack(const T &elem)
{
if ( (top-base)/sizeof(T*) > max_size-1)
{
handleOverflow();
}
else
{
*top=elem;
top++;
}

}

void popStack()
{
if (isEmpty())
{
return;
}
else
{
top--;
}

}

const T& getTop() const
{
if (isEmpty())
{
return NULL;
}
return *(top-1);

}

bool isEmpty()
const
{
if (top==base)
{
return true;
}
return false;

}

private:
static const int init_size=100;
unsigned int max_size;

T *top, *base;

void handleOverflow()
{

unsigned int pre_size=max_size;
T* pre_base=base;
max_size*=2;

base=(T*)malloc(sizeof(T)*max_size);
memcpy(base, pre_base, pre_size*sizeof(T));
delete pre_base;
pre_base=NULL;

top=base+pre_size;

}

};

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.