C++中数据对齐问题。struct、union、enum,类继承。再谈sizeof()
首先是struct,在C++中,结构体其实和class有很大的相似了。但是有一点不同的是,struct默认是public,而class中是private.
当然,struct继承等用法也是可以的。
共用体的声明方式是:

枚举的声明方式与共用体比较相似

其中a初始化为0,后面默认增1,若已经初始化,则后面再增1,比如d=6在这里。
struct长度计算

大家猜一下,s1 x;int b=sizeof(x);
他的结果会是多少呢?有人会觉得应该是1+8+4+1=14.

实际上是24.为什么会是这样呢?这个和结构体的对齐方式有很大关系。总之有两条
1、整体空间是最大成员占用字节的整数倍,比如这里最大字节占用的是double,他为8,那肯定是8,16,24...
2、内存按照结构体中的数据成员先后排序,并且当前地址应该是以当前成员所占用空间的整数倍。比如在这里double b占用的是8个字节,那么以摆字节就应该是8,16,24.而char a,只有一个字节,则前面空间自动补齐。
按照上面两点的规则,我们不难得出8+8+4+1,但是应该是8的整数倍,所以是24.
这里有必要补充一下:在Linux+gcc环境下,若最大成员是4,则整体空间只需是4的倍数即可。所以这里只需要是4的倍数,4,8,12,16,20,24..
第二点,在Linux+gcc环境下,若某成员类型所占字节数超过4,那前面已摆放空间只需要是4的倍数即可。这里double b;前面只需补齐4个即可,而不需补齐8个。
故会出现整体空间是20的情况。4+8+4+1=17.但是应该是4的倍数,则为20.
那么联合体应该是怎么样的呢?
很显然联合体取值的时候只能取其中的一个,那么,联合体就是多个成员公用一个内存空间。大家很自然的就想到了,最大那个成员所占用的空间就是联合体的空间了。
讲到了数据的对齐方式,那我们就非常有必要讲一下两种不同机器的存储方式:大端存储模式和小端存储模式。
大端存储模式:高位字节存储低地位内存中,低位字节存储高位。这里均以0x12345678为例。

小端存储模式:低位存储在高位内存中

在小端系统中,b的ASCII为多少?
union enumName {
int i;
unsigned char ch[];
};
int _tmain(int argc, _TCHAR* argv[])
{
enumName student;
student.i=0x1420;
char b=student.ch[];
}
答案应该是32
小端是低位放低位,高位放高位。则是20 14这样排放。ch[0]等于0x20.
其实我们平常使用的计算机很多都是小端存储。
Update
本来以为数据对齐的问题已经讲完,但是今天看到了一道笔试题,觉得非常有必要再说一下关于类中,继承类的数据成员对齐问题。
class A{
public:
int a;
char b;
};
class B:public A{
public:
char c;
};
我们想一下,sizeof(B)是多少呢?肯定有人觉得他应该是9或者1.
但是其实答案是12.
为什么是12呢?这里我们就要注意到类的对齐方式了。
显然B继承自A,那么B应该包括了A的数据成员,那么对于A来说大小应该是8,这个和结构体的计算方式是一致的。
特别注意第二点,子类的对齐还要考虑父类的情况,在这里表现的就是,A中最大为4,那么最后的数据大小应该是4的整数倍,4,8,12,。
这里本来应该是8+1.但需要自动补齐,因此是12.
转载请注明出处:http://www.cnblogs.com/xiaoyi115/p/3622135.html
C++中数据对齐问题。struct、union、enum,类继承。再谈sizeof()的更多相关文章
- 关于C与C++的struct,union,enum用法差异
对着代码说话: #include <stdio.h> #include <stdlib.h> struct test { int abc; }; enum _enum {A,B ...
- C++中数据对齐
大体看了看数据对齐,不知道是否正确,总结如下: struct A { char name; double dHeight; int age; }; sizeof(A) = (1+7+8+4+4) = ...
- java enum类探索
参考网址1, 参考网址2 一直对枚举有点迷惑,现在试着理解枚举. 1.首先,普通类与枚举 的区别.拿两个例子比较吧 普通类: /** * 一个普通类 * @author Administrator * ...
- 如何使用Java中的Enum类
Java1.5 中出现了枚举类型.当一个值都在一个固定的范围内变化,那就可以使用 enum 类型来定义.比如说,一周有七天,一年有四季. 没有枚举类的时候,我们用常量来定义一组范围值的: public ...
- CSAPP阅读笔记-struct, union, 数据对齐-来自第三章3.9的笔记-P183-P191
1.数据对齐 为什么要对齐:通俗点解释就是CPU对数据访问时,每次都是取固定数量的字节数,假如一次取4个字节,若有个int存在0x01-0x04,则一次就能取出,若存在0x03-0x06,则需要分两次 ...
- C/C++中struct/union/class内存对齐
struct/union/class内存对齐原则有四个: 1).数据成员对齐规则:结构(struct)(或联合(union))的数据成员,第一个数据成员放在offset为0的地方,以后每个数据成员存储 ...
- enum,struct,union类型使用和长度
VC,C++ Builder和lcc三个编译器 间枚举类型enum长度的情况. 各种C编译器默认的字节对齐数不一致,要写通用的代码,经常就是使用 #pragma pack(1) ... #pragma ...
- C结构体中数据的内存对齐问题
转自:http://www.cnblogs.com/qwcbeyond/archive/2012/05/08/2490897.html 32位机一般默认4字节对齐(32位机机器字长4字节),64位机一 ...
- C语言的struct/union字节对齐
C语言的一大优势就是对内存空间的控制,当然,一般情况下对于开发人员来说都是透明的.看一个始终困扰初学者的问题:字节对齐! 先看四个重要的基本概念:1.数据类型自身的对齐值:对于char型数据,其自身对 ...
随机推荐
- win10激活(转)
批处理命令激活方法,此方法和激活码可激活 180天 先来说下使用激活码使用方法: 1.同时按下Win键+X,然后选择命令提示符(管理员) 2.在命令提示符中依次输入: slmgr.vbs /upk ( ...
- Leetcode 665.非递减数列
非递减数列 给定一个长度为 n 的整数数组,你的任务是判断在最多改变 1 个元素的情况下,该数组能否变成一个非递减数列. 我们是这样定义一个非递减数列的: 对于数组中所有的 i (1 <= i ...
- PAT——甲级1042:Shuffling Mashine
终于做到甲级了 就一个感觉....题目是真的看不懂,亏我还是四六级都过了的人....可是看完题愣是一点都不懂是什么意思. 1042 Shuffling Machine (20 point(s)) Sh ...
- JAVA并发-线程协作
这段时间有点忙,技术博客更新的比较少,今天更新一下相关并发的常用线程协作的类吧. ExecutorService 线程池,用于创造和复用线程,他有几种模式. 我举一个自定义线程池数量的例子如下 Exe ...
- nginx 匹配路由分发php和golang
大概这么个形式,可以走通 server { listen ; server_name localhost; root "E:/wwwroot180/public"; # 匹配指定路 ...
- composer 库无法提交git
composer require firebase/php-jwt 安装了该库,想提交到版本库,无论如何也提交不上去,.ignore中也没忽略,网上寻找答案,说有个.git文件夹需要删除 PHPSTO ...
- 第十七篇:django基础(二)
本篇内容 简单图书crm系统 编写views views:作为MVC中的C,接收用户的输入,调用数据库Model层和业务逻辑Model层,处理后将处理结果渲染到V层中去. app01/views.py ...
- Android的WebView有哪些坑?
今天逛知乎的时候,看到一个有关Android应用开发中,WebView 的问题,算是开发中比较常见的问题了吧,而且赞同数比较多的答案,确实回答得还不错,这里小编就整理了一下,分享出来大家借鉴借鉴,避免 ...
- P2857 [USACO06FEB]稳定奶牛分配Steady Cow Assignment
题目描述 Farmer John's N (1 <= N <= 1000) cows each reside in one of B (1 <= B <= 20) barns ...
- deeplearning4j——卷积神经网络对验证码进行识别
一.前言 计算机视觉长久以来没有大的突破,卷积神经网络的出现,给这一领域带来了突破,本篇博客,将通过具体的实例来看看卷积神经网络在图像识别上的应用. 导读 1.问题描述 2.解决问题的思路 3.用DL ...