1、基本数据类型

sizeof 是一个关键字,它是一个编译时运算符,用于判断变量或数据类型的字节大小。

sizeof 运算符可用于获取类、结构、共用体和其他用户自定义数据类型的大小。

使用 sizeof 的语法如下:

sizeof (data type)

其中,data type 是要计算大小的数据类型,包括类、结构、共用体和其他用户自定义数据类型。

请尝试下面的实例,理解 C++ 中 sizeof 的用法。复制并黏贴下面的 C++ 程序到 test.cpp 文件中,编译并运行程序。

int main()
{
cout << "Size of char : " << sizeof(char) << endl; //
cout << "Size of bool : " << sizeof(bool) << endl; // cout << "Size of int : " << sizeof(int) << endl; //
cout << "Size of short int : " << sizeof(short int) << endl;//
cout << "Size of long int : " << sizeof(long int) << endl; //
cout << "Size of long : " << sizeof(long) << endl; // cout << "Size of float : " << sizeof(float) << endl; // cout << "Size of double : " << sizeof(double) << endl; //
cout << "Size of long double : " << sizeof(long double) << endl;//
cout << "Size of wchar_t : " << sizeof(wchar_t) << endl; //
system("pause");
return ;
}

 2、字符串及字符数组

  数组作为函数的形参传递时,退化为指针。

size_t getPtrSize(char *ptr)
{
return sizeof(ptr);
} int main()
{
// hello 有 5 个字符,但总字节个数要额外加1个字节(结束符),所以是 6
char szHello[] = "Hello"; //字符串
//字符数组
char a[] = { 'h','e','l','l','o' };
char b[] = { 'h','e','l','l','o' };
char c[][]= { 'h','e','l','l','o' }; cout << "The size of a char is: "<< sizeof(char) //
<< "\nThe length of " << szHello << " is: " << sizeof (szHello) //6,字符串大小 = 本身字符 + '\0'
<< "\nThe size of the pointer is "<< getPtrSize(szHello) << endl;//4 ,当64位机时,指针位8字节 cout << "The size of a a array is: " << sizeof(a) //
<< "\nThe size of a b array is: " << sizeof(b) //
<< "\nThe size of a c array is: " << sizeof(c) //6 = 1*6
<< "\nThe size of a c0 array is: " << sizeof(c[]) //3 = 1*3 相当于一个一维数组 << endl;
system("pause");
}

3、指针

  32位机和64位机,指针大小分别为:4 和 8 。

int main()
{
char a[];
cout << "The size of a a array is: " << sizeof(a) //3,表示数组大小
<< "\nThe size of a a array is: " << sizeof(a[]) //1,表示数组的第一个字符占得大小
<< endl; // 数组指针,一个指针,指向有3个元素的一维数组,大小为一个指针的大小,4个字节
// 执行 a1+1 时,要跨过3个 char 型字符长度的大小(相当于跨过这个数组指针的单元大小)
char (*a1)[];
//*a1[0] = 6;
cout << "\nThe size of a a1 array is: " << sizeof(a1) //4,表示指针
<< "\nThe size of a a1 array is: " << sizeof(*a1[]) //1,表示指针指向的字符数组的第0个字符
<< "\nThe size of a a1 array is: " << sizeof(a1[]) //3,表示指针指向的这个字符数组
<< endl; // 指针数组,有3个指针
char *a2[];
cout << "\nThe size of a a2 array is: " << sizeof(a2) //12,表示 3*4=12
<< "\nThe size of a a2 array is: " << sizeof(a2[]) //4,表示第一个指针 << endl; system("pause");
}

4、类

   类也是一种数据类型,也就是,固定大小内存块的别名。

  定义一个类后,是一个抽象概念,不分配内存,只有当定义了对象后才分配固定大小的内存。

 一个类所占的固定内存大小,计算时需要对齐补全。选择4的倍数,结构体内最长数据元素的整数倍。

  此外,类中定义的 static 变量是存在全局数据区内,不计算在类的内存中。

  类中成员函数,也不计算在内。(因为函数代码和变量,是分开存放的)

  比如:

// 总共占用:4+4+4=12
class A
{
bool a; //
int b; //
bool c; //
}; // 总共占用:1+1=2(自动补全为4),,4+4=8
class B
{
bool a; //
bool b; //
int c; //
}; int main()
{
A a1;
B b1;
cout << sizeof(a1) << endl; //
cout << sizeof(b1) << endl; //
system("pause");
return ;
}

  另外,需要注意,对于空类:

  1.   定义空的类,实例化后,占用空间为1个字节;
  2.   多重继承还是1个字节;
  3.   虚继承有指针,是4个字节。

  之前看过几篇博客,都说是为了让对象能够有唯一的地址以区别不同的对象。这一个字节用来干什么的呢?里面的值是多少无所谓,因为这个字节只是用来占位置而已,正如上面打印的ab的地址一样,它们各自占用一个byte的内存,紧挨着。我们可以通过地址的不同来区别它们。

其实这个问题本身没什么意义,只是探究C++对象内存模型的一个敲门砖。

// 总共占用:1
class A
{ };
// 多重继承还是:1
class B :public A
{ }; // 虚继承是:4,因为虚继承要有个虚表,这是个指针
class C :virtual public A
{ }; int main()
{
A a1;
B b1;
C c1;
cout << sizeof(a1) << endl; //
cout << sizeof(b1) << endl; //
cout << sizeof(c1) << endl; //
system("pause");
return ;
}

参考文献:https://blog.csdn.net/Jacketinsysu/article/details/52207285

C++(十五) — sizeof 运算符的更多相关文章

  1. C++学习基础十五--sizeof的常见使用

    sizeof的常见用法 1. 基本类型所占的内存大小 类型 32位系统(字节) 64位系统(字节) char 1 1 int 4 4 short 2 2 long 4 8 float 4 4 doub ...

  2. C++(三十五) — 运算符重载

    运算符重载的实质:函数重载.除了增加一个关键字 operator 外,与函数重载没有区别,都是通过该类的某个对象来访问重载运算符. (1)重载运算符时,运算符运算顺序和优先级不变,操作数个数不变: ( ...

  3. 我的MYSQL学习心得(五) 运算符

    我的MYSQL学习心得(五) 运算符 我的MYSQL学习心得(一) 简单语法 我的MYSQL学习心得(二) 数据类型宽度 我的MYSQL学习心得(三) 查看字段长度 我的MYSQL学习心得(四) 数据 ...

  4. 我的MYSQL学习心得(十五) 日志

    我的MYSQL学习心得(十五) 日志 我的MYSQL学习心得(一) 简单语法 我的MYSQL学习心得(二) 数据类型宽度 我的MYSQL学习心得(三) 查看字段长度 我的MYSQL学习心得(四) 数据 ...

  5. Sizeof运算符小结

    以下内容援引自<C Primer Plus>中文版第五版Page95 Sizeof运算符以字节为单位返回其操作数的大小.(在C中,1个字节被定义为char类型所占用空间的大小.在过去,1个 ...

  6. NeHe OpenGL教程 第四十五课:顶点缓存

    转自[翻译]NeHe OpenGL 教程 前言 声明,此 NeHe OpenGL教程系列文章由51博客yarin翻译(2010-08-19),本博客为转载并稍加整理与修改.对NeHe的OpenGL管线 ...

  7. UVA 1252 十五 Twenty Questions

    十五 Twenty Questions Time Limit:3000MS     Memory Limit:0KB     64bit IO Format:%lld & %llu Submi ...

  8. NeHe OpenGL教程 第三十五课:播放AVI

    转自[翻译]NeHe OpenGL 教程 前言 声明,此 NeHe OpenGL教程系列文章由51博客yarin翻译(2010-08-19),本博客为转载并稍加整理与修改.对NeHe的OpenGL管线 ...

  9. NeHe OpenGL教程 第二十五课:变形

    转自[翻译]NeHe OpenGL 教程 前言 声明,此 NeHe OpenGL教程系列文章由51博客yarin翻译(2010-08-19),本博客为转载并稍加整理与修改.对NeHe的OpenGL管线 ...

随机推荐

  1. 利用epoll实现异步IO

    之前异步IO一直没搞明白,大致的理解就是在一个大的循环中,有两部分:第一部分是监听事件:第二部分是处理事件(通过添加回调函数的方式).就拿网络通信来说,可以先通过调用 select 模块中的 sele ...

  2. lombok插件使用

    1.1 lombok介绍 lombok 是一个可以帮助我们简化java代码编写的工具类,尤其是简化javabean的编写,可以通过采用注解的方式,消除代码中的构造方法,getter/setter等代码 ...

  3. 好难忘又伤心一个非常好的学习js群解散了

    不知道为什么看到web前端之天天向上这个群解散,好难过.应该可以说,这个群是我见过比较靠谱的群,大家都非常热情帮助.那些管理员管理的非常好,突然解散了.觉得好可惜,也不会因为你是菜鸟不让你加,感觉好可 ...

  4. sql中in和exists的区别

    in 和exists in是把外表和内表作hash 连接,而exists 是对外表作loop 循环,每次loop 循环再对内表进行查询. 一直以来认为exists 比in 效率高的说法是不准确的.如果 ...

  5. [luogu4234]最小差值生成树

    [luogu4234]最小差值生成树 luogu 从小到大枚举边,并连接,如果已连通就删掉路径上最小边 lct维护 \(ans=min(E_{max}-E_{min})\) #include<b ...

  6. Python 爬虫 学习一

    # coding: utf8 import requests from bs4 import BeautifulSoup PhotoName = 1 DATA = [] def save_img(ur ...

  7. 我的Android进阶之旅------>解决Jackson、Gson解析Json数据时,Json数据中的Key为Java关键字时解析为null的问题

    1.问题描述 首先,需要解析的Json数据类似于下面的格式,但是包含了Java关键字abstract: { ret: 0, msg: "normal return.", news: ...

  8. corethink功能模块探索开发(十七)opencmf.php 配置文件

    图样: opencmf.php存在于每个模块的根目录,是模块配置文件. 能进行持久化配置参数保存,一开始我以为是写文件或者做缓存,后来在数据库中发现admin_module表,存储了每个模块的配置参数 ...

  9. socketserver 源码剖析:

    socketserver 源码剖析[有图有真相]: (一).Socketserver 内部流程调用图:        详解:  1.self.RequestHandlerClass() = MyCla ...

  10. vue项目 dev正常 build发生错误

    提取错误信息: 这个文件有错误,检查并修改即可 经过排除检查错误地方如下:多了个逗号