如何進(jìn)行Stack源碼分析

今天就跟大家聊聊有關(guān)如何進(jìn)行Stack源碼分析,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。

創(chuàng)新互聯(lián)建站網(wǎng)站建設(shè)服務(wù)商,為中小企業(yè)提供成都網(wǎng)站建設(shè)、成都做網(wǎng)站服務(wù),網(wǎng)站設(shè)計(jì),網(wǎng)站托管、服務(wù)器租用等一站式綜合服務(wù)型公司,專業(yè)打造企業(yè)形象網(wǎng)站,讓您在眾多競(jìng)爭(zhēng)對(duì)手中脫穎而出創(chuàng)新互聯(lián)建站

我們介紹另一種底層也是用數(shù)據(jù)方式實(shí)現(xiàn)的集合,它就是Stack集合。Stack與ArrayList和Vector相比,有自己獨(dú)特的一些特性。正是因?yàn)镾tack有自己獨(dú)特的特性,所以在使用上Stack與ArrayList、Vector相比有些區(qū)別,所以下面我們先了解一下Stack集合的基本使用,然后在分析Stack集合的底層源碼。

Stack也就是棧,它和其它集合相比它的特性就是后進(jìn)先出,也就是后添加到Stack集合中的元素,會(huì)被添加到棧的最頂位置。下面我們看一下在Stack集合中的都包括哪些方法。

如何進(jìn)行Stack源碼分析

下面我們通過一個(gè)簡(jiǎn)單的例子來演示上面方法的基本使用。

如何進(jìn)行Stack源碼分析

如何進(jìn)行Stack源碼分析

下面我們分析一下Stack集合的底層源碼,還是和ArrayList集合和Vector集合一樣,我們先看一下Stack集合的初始化。

如何進(jìn)行Stack源碼分析

源碼中只有一個(gè)無參的構(gòu)造主法,這就說明,在我們創(chuàng)建Stack對(duì)象時(shí),并不會(huì)執(zhí)行底層數(shù)組的初始化。

如何進(jìn)行Stack源碼分析

如何進(jìn)行Stack源碼分析

如何進(jìn)行Stack源碼分析

如何進(jìn)行Stack源碼分析

上面的代碼是Stack集合把元素添加到棧頂?shù)姆椒?,我們看上面的代碼是不是感覺似曾相識(shí),好像和Vector集合的底層源碼一模一樣。這是因?yàn)镾tack集合是Vector集合的子類,也就是Stack集合默認(rèn)繼承了Vector集合。下面是底層源碼。

如何進(jìn)行Stack源碼分析

所以我們可以理解為Stack集合的底層實(shí)現(xiàn)原理和Vector集合是一樣的,包括底層數(shù)組的自動(dòng)擴(kuò)展規(guī)律等特性都是一樣的。也就是說Stack集合和Vector集合一樣當(dāng)?shù)讓訑?shù)據(jù)超過最大容量時(shí),會(huì)自動(dòng)擴(kuò)展為原來的2倍容量來存儲(chǔ)元素。

下面我們看一下Stack集合中其它方法的底層實(shí)現(xiàn),因?yàn)檫@些方法邏輯已經(jīng)在Vector集合中介紹過了,并且方法的實(shí)現(xiàn)邏輯比較簡(jiǎn)單,這里我們就不在詳細(xì)分析了,只是簡(jiǎn)單展示。

  • peek()

如何進(jìn)行Stack源碼分析

如何進(jìn)行Stack源碼分析

  • pop()

如何進(jìn)行Stack源碼分析

如何進(jìn)行Stack源碼分析

  • search(Object o)

如何進(jìn)行Stack源碼分析

看完上述內(nèi)容,你們對(duì)如何進(jìn)行Stack源碼分析有進(jìn)一步的了解嗎?如果還想了解更多知識(shí)或者相關(guān)內(nèi)容,請(qǐng)關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝大家的支持。

本文題目:如何進(jìn)行Stack源碼分析
網(wǎng)站網(wǎng)址:http://muchs.cn/article20/pihsco.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供ChatGPT微信公眾號(hào)、服務(wù)器托管網(wǎng)頁(yè)設(shè)計(jì)公司、響應(yīng)式網(wǎng)站自適應(yīng)網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

微信小程序開發(fā)