存储概念|详解大小端存储

这篇具有很好参考价值的文章主要介绍了存储概念|详解大小端存储。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。


0.前言

1.数据的高位和低位

2.高地址和低地址 

3.大端存储和小端存储 

4.为什么会有大小端存储

5.验证C语言的数据的存储是大端还是小端


0.前言

大小端存储是计算机存储的一个设计概念,涉及了高地址和低地址,数据的高位和低位等概念,所以在理解大小端存储之前,需要知道什么是高地址和低地址,什么是数据的高位和低位这些概念。

1.数据的高位和低位

数据的高位是数据的左边位置的数,数据的低位是数据右边位置的数,数据的高位和低位又称高字节和低字节。

拿一个十进制数来讲,例如简单的1234,那么数据的高位是在左边,也就是1是1234的高位数据的低位是在数据的右边,4是数据的低位高位和低位是一个相对的概念,在1234中,相对于4,1是高位,相对于1,4是低位。如图所示

存储概念|详解大小端存储

 拿八位二进制数来讲,1111 0000是八位二进制数,类似的,1111是数据的高位,而0000是数据的低位

存储概念|详解大小端存储

2.高地址和低地址 

为了便于管理存储地址,给地址进行编号,值较大的地址是高地址,值较小的地址是低地址

 拿4位16进制的数来讲,该数表示一个地址,例如0xFFFF和0x0000,则0xFFFF则是高地址,0x0000则是低地址,如图所示。

存储概念|详解大小端存储

3. 大端存储和小端存储 

大端存储,是将数据的低位字节放到高地址处,高位字节放到低地址处。

小端存储,是将数据的低位字节放到低地址处,高位字节放到高地址处。

大端存储和小端存储记忆时,可以理解为将低位字节放到大端还是小端?大端存储就是将低为放到高地址,小端就是将低位放到低地址,这样方便记忆

例如将4位16进制数存储到地址中,数据为0x1234,如图所示

存储概念|详解大小端存储

存储概念|详解大小端存储

 大端存储和小端存储并没有优劣之分

4.为什么会有大小端存储

对于位数大于8的处理器,寄存器的宽度大于1个字节,那么将会存在如何将多个字节安排在寄存器内,就可以有大小端存储两种方法,大小端存储并没有优劣之分,都是存储的方法文章来源地址https://www.toymoban.com/news/detail-423932.html

 5. 验证C语言的数据的存储是大端还是小端

//判断大小端
//假设右边是高地址,左边是低地址
int main()
{
	int a = 1; // 0x0000 0001
	//如果是大端 低位字节放到高地址,高位字节放到低地址
	//00 00 00 01
	//如果是小端 高位字节放到高地址,低位字节放到低地址
	//01 00 00 00
	char* p = (char*)&a; //字符指针只读1个字节,读8位
    //如果是大端存储,则p读取的值是0
    //如果是小端存储,则p读取的值是1
	if (*p == 1)
		printf("小端\n");
	else
		printf("大端\n");
	return 0;
}

到了这里,关于存储概念|详解大小端存储的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【图】概念、存储结构、广度优先遍历遍历、深度优先遍历 - 详解

    目录 前言 一、图 1.1、基本概念 二、图的存储结构 2.1、存储结构 2.1、邻接矩阵(考察重点) 2.1.1、代码实现 2.2、邻接表 2.3.1、无向邻接表存储 2.3.2、有向图邻接表存储 3.1、图的广度优先遍历(层序遍历) 3.2、图的深度优先遍历 本章主要讲的是图的基本概念以及应用,面试

    2024年02月08日
    浏览(52)
  • 图详解第一篇:图的基本概念及其存储结构(邻接矩阵和邻接表)

    这篇文章开始,我们来学习一种高阶数据结构——图 图是由顶点集合及顶点间的关系(边)组成的一种数据结构:G = (V, E)。 其中: 顶点集合V = {x|x属于某个数据对象集}是有穷非空集合; E = {(x,y)|x,y属于V}或者E = {x, y|x,y属于V Path(x, y)}是顶点间关系的有穷集合,也叫做边的集

    2024年02月08日
    浏览(42)
  • C语言——数据在内存中的存储【整型数据在内存中的储存,大小端字节序储存,浮点型数据在内存中的储存】

    📝前言: 在前面的三篇文章中我们已经完成了对字符函数和字符串函数的学习,现在就让我们探索新领域,更加深入的理解** 数据在内存中的存储方式 **: 1,整数在内存中的存储 2,⼤⼩端字节序存储 3,浮点数在内存中的存储 🎬个人简介:努力学习ing 📋个人专栏:C语言

    2024年02月04日
    浏览(49)
  • C/C++数据结构之深入了解树与二叉树:概念、存储结构和遍历

    树是一种常见的数据结构,它在计算机科学和数学中都有广泛的应用。树结构的最简单形式是二叉树,本文将深入探讨树和二叉树的概念、存储结构以及二叉树的遍历,并提供一些实际的代码示例来帮助理解这些概念。 树 (Tree) 树是一种层次性数据结构,由节点(或称为顶点

    2024年02月06日
    浏览(51)
  • 大数据技术原理与应用 概念、存储、处理、分析和应用(林子雨)——第三章 分布式文件系统HDFS

    大数据要解决数据存储问题,所以有了分布式文件系统(DFS),但可能不符合当时的一些应用需求,于是谷歌公司开发了GFS(Google file System)。GFS是闭源的,而HDFS是对GFS的开源实现。 1.GFS和DFS有什么区别? GFS(Google File System)和DFS(Distributed File System)都是分布式文件系统,

    2024年02月03日
    浏览(84)
  • 【c语言】详解c语言#预处理期过程 | 宏定义前言

    c语言系列专栏: c语言之路重点知识整合   创作不易,本篇文章如果帮助到了你,还请点赞支持一下♡𖥦)!!  主页专栏有更多知识,如有疑问欢迎大家指正讨论,共同进步! 给大家跳段街舞感谢支持!ጿ ኈ ቼ ዽ ጿ ኈ ቼ ዽ ጿ ኈ ቼ ዽ ጿ ኈ ቼ ዽ ጿ ኈ ቼ 代码编译到执

    2024年02月01日
    浏览(52)
  • 数据在内存中的储存·大小端(文字+画图详解)(c语言·超详细入门必看)

    前言:Hello,大家好,我是心跳sy😘,本节我们介绍c语言的两种基本的内置数据类型:数值类型和字符类型在内存中的储存方法,并对大小端进行详细介绍(附两种大小端判断方法),文章每个例题和知识点都会有详细的解释,友友们放心食用,我们一起来看看吧~!! 👉我

    2024年02月10日
    浏览(38)
  • 【算法与数据结构】--前言

    欢迎来到《算法与数据结构》专栏!这个专栏将引领您进入计算机科学领域中最重要、最精彩的领域之一:算法与数据结构。不管您是一名初学者,还是已经拥有一定编程经验的开发者,都可以从这里找到有益的知识和实践。 在计算机科学的世界里,算法和数据结构是至关重

    2024年02月07日
    浏览(246)
  • 数据结构前言

    数据结构是计算机存储、组织数据的方式。数据结构是指相互之间存在一种或多种特定关系的数据元素的集合。 上面是百度百科的定义, 通俗的来讲数据结构就是数据元素集合与数据元素集合或者数据元素与数据元素之间的组成形式。 举个简单明了的例子: 就像一个图书馆

    2024年02月09日
    浏览(53)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包