golang 切片擴(kuò)容的探討

golang 切片擴(kuò)容的探討

分以下幾種情況:
1.切片每次新增個(gè)數(shù)不超過原來的1倍峡蟋,且每次增加數(shù)不超過1024個(gè),且增加后總長(zhǎng)度小于1024個(gè)赎婚,這種情況下擴(kuò)容后為原來的2倍

    s1 := make([]int, 0)
    fmt.Printf("The capacity of s1: %d\n", cap(s1))
    for i := 1; i <= 17; i++ {
        s1 = append(s1, i)
        fmt.Printf("s1(%d): len: %d, cap: %d\n", i, len(s1), cap(s1))
    }
    fmt.Println()
結(jié)果:
/*
The capacity of s1: 0
s1(1): len: 1, cap: 1
s1(2): len: 2, cap: 2
s1(3): len: 3, cap: 4
s1(4): len: 4, cap: 4
s1(5): len: 5, cap: 8
s1(6): len: 6, cap: 8
s1(7): len: 7, cap: 8
s1(8): len: 8, cap: 8
s1(9): len: 9, cap: 16
s1(10): len: 10, cap: 16
s1(11): len: 11, cap: 16
s1(12): len: 12, cap: 16
s1(13): len: 13, cap: 16
s1(14): len: 14, cap: 16
s1(15): len: 15, cap: 16
s1(16): len: 16, cap: 16
s1(17): len: 17, cap: 32
*/

2.切片一次新增個(gè)數(shù)超過原來1倍逊彭,但不超過1024個(gè)瓦戚,且增加后總長(zhǎng)度小于1024個(gè)团驱,這種情況下擴(kuò)容后比實(shí)際具有的總長(zhǎng)度還要大一些摸吠。

    s2 := make([]int, 10)
    fmt.Printf("The capacity of s2: %d\n", cap(s2))
    r1 := append(s2, make([]int, 5)...)
    fmt.Printf("r1: len: %d, cap: %d\n", len(r1), cap(r1))
    r2 := append(s2, make([]int, 11)...)
    fmt.Printf("r2: len: %d, cap: %d\n", len(r2), cap(r2))
    r3 := append(s2, make([]int, 21)...)
    fmt.Printf("r3: len: %d, cap: %d\n", len(r3), cap(r3))
    fmt.Printf("注意:像r2,r3 一次增加個(gè)數(shù)超過原容量的1倍,增加后結(jié)果比實(shí)際總長(zhǎng)度預(yù)想的稍大一點(diǎn) \n")
    fmt.Println()
結(jié)果:
/*
The capacity of s2: 10
r1: len: 15, cap: 20
r2: len: 21, cap: 22
r3: len: 31, cap: 32
注意:像r2,r3 一次增加個(gè)數(shù)超過原容量的1倍嚎花,增加后結(jié)果比實(shí)際總長(zhǎng)度預(yù)想的稍大一點(diǎn) 
*/

3.原切片長(zhǎng)度超過1024時(shí)寸痢,一次增加容量不是2倍而是0.25倍,每次超過預(yù)定的都是0.25累乘

    // 1024 * 0.25 = 256
    s3 := make([]int, 1024)
    fmt.Printf("The capacity of s3: %d\n", cap(s3))
    r4 := append(s3, make([]int, 200)...)
    fmt.Printf("r4: len: %d, cap: %d\n", len(r4), cap(r4))
    r5 := append(s3, make([]int, 256)...)
    fmt.Printf("r5: len: %d, cap: %d\n", len(r5), cap(r5))
    // 1280 * 0.25 = 320
    r6 := append(s3, make([]int, 266)...)
    fmt.Printf("r6: len: %d, cap: %d\n", len(r6), cap(r6))
    fmt.Printf("注意:像r6 一次增加個(gè)數(shù)超過原容量的0.25倍紊选,增加后結(jié)果比原容量1.25倍預(yù)想的稍大一點(diǎn) \n")
    fmt.Println()
結(jié)果:
/*
The capacity of s3: 1024
r4: len: 1224, cap: 1280
r5: len: 1280, cap: 1280
r6: len: 1290, cap: 1696
注意:像r6 一次增加個(gè)數(shù)超過原容量的0.25倍啼止,增加后結(jié)果比原容量1.25倍預(yù)想的稍大一點(diǎn)
*/

說明下:第三種情況,又分為兩種丛楚,一種是原長(zhǎng)度不小于1024時(shí)族壳,一次擴(kuò)容后為原來的1.25倍(當(dāng)然一次增加的個(gè)數(shù)不超過原長(zhǎng)度的0.25倍)憔辫;第二種情況就是一次增加個(gè)數(shù)超過原長(zhǎng)度的0.25倍趣些,擴(kuò)容后其容量比預(yù)想的總長(zhǎng)度稍大點(diǎn),就比如 r6: len: 1290, cap: 1696, 一次擴(kuò)容長(zhǎng)度大于0.25倍贰您,擴(kuò)容后坏平,其實(shí)際容量比0.25累乘預(yù)想的大一點(diǎn),比如10241.251.25 = 1600 锦亦,實(shí)際為1696.

示例代碼保存在GitHub地址:點(diǎn)擊

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末舶替,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子杠园,更是在濱河造成了極大的恐慌顾瞪,老刑警劉巖,帶你破解...
    沈念sama閱讀 212,718評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異陈醒,居然都是意外死亡惕橙,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,683評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門钉跷,熙熙樓的掌柜王于貴愁眉苦臉地迎上來弥鹦,“玉大人,你說我怎么就攤上這事爷辙”蚧担” “怎么了?”我有些...
    開封第一講書人閱讀 158,207評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵膝晾,是天一觀的道長(zhǎng)栓始。 經(jīng)常有香客問我,道長(zhǎng)血当,這世上最難降的妖魔是什么混滔? 我笑而不...
    開封第一講書人閱讀 56,755評(píng)論 1 284
  • 正文 為了忘掉前任,我火速辦了婚禮歹颓,結(jié)果婚禮上坯屿,老公的妹妹穿的比我還像新娘。我一直安慰自己巍扛,他們只是感情好领跛,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,862評(píng)論 6 386
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著撤奸,像睡著了一般吠昭。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上胧瓜,一...
    開封第一講書人閱讀 50,050評(píng)論 1 291
  • 那天矢棚,我揣著相機(jī)與錄音,去河邊找鬼府喳。 笑死蒲肋,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的钝满。 我是一名探鬼主播兜粘,決...
    沈念sama閱讀 39,136評(píng)論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼弯蚜!你這毒婦竟也來了孔轴?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,882評(píng)論 0 268
  • 序言:老撾萬榮一對(duì)情侶失蹤碎捺,失蹤者是張志新(化名)和其女友劉穎路鹰,沒想到半個(gè)月后贷洲,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,330評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡晋柱,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,651評(píng)論 2 327
  • 正文 我和宋清朗相戀三年恩脂,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片趣斤。...
    茶點(diǎn)故事閱讀 38,789評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡俩块,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出浓领,到底是詐尸還是另有隱情玉凯,我是刑警寧澤,帶...
    沈念sama閱讀 34,477評(píng)論 4 333
  • 正文 年R本政府宣布联贩,位于F島的核電站漫仆,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏泪幌。R本人自食惡果不足惜盲厌,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,135評(píng)論 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望祸泪。 院中可真熱鬧吗浩,春花似錦、人聲如沸没隘。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,864評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)右蒲。三九已至阀湿,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間瑰妄,已是汗流浹背陷嘴。 一陣腳步聲響...
    開封第一講書人閱讀 32,099評(píng)論 1 267
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留间坐,地道東北人灾挨。 一個(gè)月前我還...
    沈念sama閱讀 46,598評(píng)論 2 362
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像眶诈,于是被迫代替她去往敵國(guó)和親涨醋。 傳聞我的和親對(duì)象是個(gè)殘疾皇子瓜饥,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,697評(píng)論 2 351