C++类中包含stl容器时,使用sizeof求大小的问题

原创 2015年11月18日 22:45:01

1.说明

这里的大小指的是sizeof(a class object)的值,也就是一个类的对象所占的字节大小,原来我一直认为类的大小会随着类成员中容器元素个数的变化而变化,后来想想又想不通,所以写了下面的代码用来测试。

2.测试代码

(1)测试类

class KFoo
{
public:
    KFoo(void)
    {
        m_nValue = 0;
        m_cEnd ='0';
        m_listValue.clear();
        m_vectorValue.clear();
        m_mapValue.clear();
    };
    ~KFoo(void){};
public:
    inline void SetValue(const int nValue)
    {
        m_nValue = nValue;
    }

public:
    int             m_nValue;
    list<int>       m_listValue;        //24
    vector<int>     m_vectorValue;      //20
    map<int, int>   m_mapValue;         //28
    char            m_cEnd;
};

(2)测试类大小的函数

#include "Foo.h"
#include <Windows.h>
#include <stdio.h>

int _tmain(int argc, _TCHAR* argv[])
{
    KFoo foo;
    foo.SetValue(0);
    foo.m_cEnd = 'a';

    printf("begin: Class object foo size = %d\n\n", sizeof(foo));


    printf("begin: list size = %d\n", sizeof(foo.m_listValue));
    for(int nIndex = 0; nIndex < 1024; ++nIndex)
    {
        foo.m_listValue.push_back(nIndex);
    }
    printf("begin: list size = %d\n\n", sizeof(foo.m_listValue));


    printf("begin: vector size = %d\n", sizeof(foo.m_vectorValue));
    foo.m_vectorValue.resize(2048);
    for(int nIndex = 0; nIndex < 2048; ++nIndex)
    {
        foo.m_vectorValue.push_back(nIndex);
    }
    printf("begin: vector size = %d\n\n", sizeof(foo.m_vectorValue));


    printf("begin: vector size = %d\n", sizeof(foo.m_mapValue));
    for(int nIndex = 0; nIndex < 4096; ++nIndex)
    {
        foo.m_mapValue.insert(make_pair<int, int>(nIndex, nIndex));
    }
    printf("begin: vector size = %d\n\n", sizeof(foo.m_mapValue));


    printf("end: Class object foo size = %d\n\n", sizeof(foo));

    system("pause");

    return 0;
}

3.结果如下图

类的大小

4.分析

类的大小不会随着成员内容器元素个数的增加而增大,容器中的元素个数增加不会增加容器变量的大小,原因是sizeof是无法求出容器所占的内存的,这些容器申请的大部分空间都是在堆上,栈上只有一部分用于管理的指针,测试得出sizeof(list)=24,sizeof(vector)=20,sizof(map)=28,这个数值和具体的编译器实现有关,测试环境vs2008+Win7 X64,可能不同的环境得出的结果不同。

5.另注

以上多为个人理解,有不正确的地方欢迎大家指出!其中把end 打成了begin,map size 打成了 vector size大家能理解就好了,我就不在重新截图了。

版权声明:本文为博主原创文章,转载请注明出处。更多精彩文章请关注微信公众号:写代码的苏东坡

相关文章推荐

C++ STL vector:sizeof(vector)

int的大小是4,定义vector vec,vec中有一个元素,sizeof(vec)=20,如果有1000个元素,则sizeof(vec)是多少? #include #include us...
  • ZCSYLJ
  • ZCSYLJ
  • 2012年08月12日 15:28
  • 4358

C++容器中 size(), capacity, reserve() ,resize() 函数讲解

size()指 目前存在的元素数。            元素个数 capacity()指 容器能存储 数据的个数      容器 容量 reserve()指定 容器 能存储数据的个数 resi...

【面试题】sizeof 获取自定义类,结构体,vector,map,string的占内存大小

#include #include #include #include using namespace std; struct a { short aa;//2 short b;//2 ...
  • bxyill
  • bxyill
  • 2012年10月02日 14:13
  • 2282

C++容器之list

简介          List是一种可在常数时间内在任何位置执行插入和删除操作的顺序容器。list是双向链表,其迭代器是双向的。与其他顺序容器(array, vector, deque)相比,li...

从零开始学C++之STL(二):实现简单容器模板类Vec(vector capacity 增长问题、allocator 内存分配器)

首先,vector 在VC 2008 中的实现比较复杂,虽然vector 的声明跟VC6.0 是一致的,如下:  C++ Code  1 2 template class _...

vector容器类的使用[c++ stl]

vector容器类的使用 郑海波 2012-4-20 南京 1.     vector容器简介: vector向量容器是一种随机访问的数组类型,它提供了对数组元素的快速访问、随机访问,以及在...

组装电脑(较难题:贪心+模拟(包含C++中STL容器的运用))

Problem Link:http://139.129.36.234/problem.php?id=1276 1276: 组装电脑 时间限制: 1 Sec  内存限制: 128...

C++ STL 基本容器使用

C++ STL 基本容器使用 一、STL简介 STL(Standard Template Library),即标准模板库,是一个具有工业强度的,高效的C++程序库。它被容纳于C++标准程序(C++ S...

C++ STL容器中erase的使用

erase()函数的功能是用来删除容器中的元素 函数原型: iterator erase(iterator where); iterator erase(iterator first,i...

C++ STL 中 map 容器的说明和使用技巧

Map是STL的一个关联容器,它提供一对一(其中第一个可以称为关键字,每个关键字只能在map中出现一次,第二个可能称为该关键字的值)的数据 处理能力,由于这个特性,它完成有可能在我们处理一对一数据的时...
  • wr132
  • wr132
  • 2014年09月22日 19:37
  • 662
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:C++类中包含stl容器时,使用sizeof求大小的问题
举报原因:
原因补充:

(最多只允许输入30个字)