CentOS 4.6 x86_64 g++ 3.4.6 中vector的Grow策略

來源:互聯網
上載者:User
寫了一個小程式,測試了一下vector是如何分配記憶體的:

Code: Select all
#include <iostream>
#include <vector>
#include <string>
using namespace std;

int main()
{
    vector<string> vec1;
    cout << "Vector size is:  " << vec1.size() << ", capacity is: " << vec1.capacity() << endl;

    for (int i=0; i<30; i++) {
        vec1.push_back("String 1");
        cout << "Vector size is:  " << vec1.size() << ", capacity is: " << vec1.capacity() << endl;
    }

    vec1.reserve(50);
    vec1.push_back("String 2");
    vec1.push_back("String 3");
    cout << "Vector size is:  " << vec1.size() << ", capacity is: " << vec1.capacity() << endl;

    return 0;
}

程式的輸出是:

Vector size is: 0, capacity is: 0
Vector size is: 1, capacity is: 1
Vector size is: 2, capacity is: 2
Vector size is: 3, capacity is: 4
Vector size is: 4, capacity is: 4
Vector size is: 5, capacity is: 8
Vector size is: 6, capacity is: 8
Vector size is: 7, capacity is: 8
Vector size is: 8, capacity is: 8
Vector size is: 9, capacity is: 16
Vector size is: 10, capacity is: 16
Vector size is: 11, capacity is: 16
Vector size is: 12, capacity is: 16
Vector size is: 13, capacity is: 16
Vector size is: 14, capacity is: 16
Vector size is: 15, capacity is: 16
Vector size is: 16, capacity is: 16
Vector size is: 17, capacity is: 32
Vector size is: 18, capacity is: 32
Vector size is: 19, capacity is: 32
Vector size is: 20, capacity is: 32
Vector size is: 21, capacity is: 32
Vector size is: 22, capacity is: 32
Vector size is: 23, capacity is: 32
Vector size is: 24, capacity is: 32
Vector size is: 25, capacity is: 32
Vector size is: 26, capacity is: 32
Vector size is: 27, capacity is: 32
Vector size is: 28, capacity is: 32
Vector size is: 29, capacity is: 32
Vector size is: 30, capacity is: 32
Vector size is: 32, capacity is: 50

所以,可以看出,這個平台上,vector的記憶體配置策略是1, 2, 4, 8, 16, 32......
g++的版本資訊是:
g++ (GCC) 3.4.6 20060404 (Red Hat 3.4.6-9)

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.