前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >CPP--借助神器VS理解内存存储(含大小端对齐)

CPP--借助神器VS理解内存存储(含大小端对齐)

作者头像
逸鹏
发布2018-04-11 15:18:14
7700
发布2018-04-11 15:18:14
举报
文章被收录于专栏:逸鹏说道逸鹏说道

前面我发过用vs看内存存储的文章,90%耐心看的都懂了,这次结合上次发的文章,对大小端对齐再来个说明(有一个没学过计算机的朋友都懂了,自己看自己的悟性定位吧~努力可以弥补99%的可能)

单位,补码之类的可以看这个:http://www.cnblogs.com/dotnetcrazy/p/8178175.html

先说说大小端对齐的事情,然后再看:

内存最小单位==》Byte,int 占 4Byte

重点来了,大于Byte的数据类型在内存中存放需要有先后顺序(一个里面放不下,那么在内存中就要有先后顺序了) 小端对齐:高内存地址放整数高位,低内存地址放整数低位(高高低低简称:倒着放(代表:X86,ARM) 大端对齐:高内存地址放整数低位,低内存地址放整数高位(高低低高简称:正着放(很多unix服务器都这样) 举个栗子:int i=0x12345678;

———————————————以前内容———————————————————

之前也有想了解这些,第一个不是学底层的不知道从何理解,第二个上网搜概念,大牛们三言两语就结束了,举得例子也比较复杂,对于非C方向的可能有点吃力,所以一直没理解。还有些网上的根本是胡说,妄以揣测,不能据理力争

今天偶然发现原来还要内存窗口之说,就慢慢的打开了思路,形成了自己的理解,有不当之处欢迎指出,小子感激不尽

进入正文:

调试的时候先打开内存窗口:

监视一下i的地址,在内存窗口里面找到这个值,发现里面有个32(50转换成16进制就是32)

验证一下下面的确是16进制

我的理解是:

这次把int改成16进制再看看调试结果:CPU是x86、ARM架构基本上都遵循 小端对齐(高地址放高位,低地址放低位)

图中很明显,内存地址越下面的越大(0x0018FBF4 > 0x0018FBB8),我们监控的地址明显是低地址 0x12345678,高位是1,低位是8。我画张转换图

然后解释下,为什么占了4个

int,占4个字节(byte),而1byte=8个bit 所以看图:

再根据低低高高的原则,就是这样放了

验证一下我的想法:(1不够了,所以用0补)

内存中存的是2进制的数,现在我们进行逆推,自然就有了这幅图:(内存最小单位byte

吐槽一下,尼玛,上学一直不太明了的东西,在VS这个神器下竟然解决了!! 扩展:(X86,ARM一般都是小端对齐,很多Unix服务器用大端对齐) 内存地址位数其实也有讲究,把VS切换到X64下,发现内存地址也长了许多

X86的是8位,也就是1byte,同理可推X64的是2byte(各个环境不同这个值可能不太一样)

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2018-01-05,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 我为Net狂 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
对象存储
对象存储(Cloud Object Storage,COS)是由腾讯云推出的无目录层次结构、无数据格式限制,可容纳海量数据且支持 HTTP/HTTPS 协议访问的分布式存储服务。腾讯云 COS 的存储桶空间无容量上限,无需分区管理,适用于 CDN 数据分发、数据万象处理或大数据计算与分析的数据湖等多种场景。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档