【答疑解惑】什么是大小端

首先一个问题,大小端是如何来的?

我们知道,在计算机系统中,内存是以字节为单位的,一个地址对应一个字节,一个字节8bit,那么数据类型比如int,short,long等在内存中肯定不止占用一个字节,这就涉及到数据的存放方式,是数据的高位字节放到高地址呢,还是数据的高位字节放在低地址呢?而这两种不同的组织方式就叫大小端。

所谓的大端模式,是指数据的低位(就是权值较小的后面那几位)保存在内存的高地址中,而数据的高位,保存在内存的低地址中,这样的存储模式有点儿类似于把数据当作字符串顺序处理:地址由小向大增加,而数据从高位往低位放;

所谓的小端模式,是指数据的低位保存在内存的低地址中,而数 据的高位保存在内存的高地址中,这种存储模式将地址的高低和数据位权有效地结合起来,高地址部分权值高,低地址部分权值低,和我们的逻辑方法一致。

举个例子来说:

32bit宽的数0x12345678在Little-endian模式CPU内存中的存放方式(假设从地址0x4000开始存放)为:

内存地址

0x4000

0x4001

0x4002

0x4003

存放内容

0x78

0x56

0x34

0x12

而在Big-endian模式CPU内存中的存放方式则为:

内存地址

0x4000

0x4001

0x4002

0x4003

存放内容

0x12

0x34

0x56

0x78

大小端一般和CPU有关,比如ARM是小端的,而MIPS是可以设置大端还是小端的。

原文发布于微信公众号 - 程序员互动联盟(coder_online)

原文发表时间:2015-08-21

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏深度学习之tensorflow实战篇

hive排序:distribute by 、sort by 、cluster by 、order by 区别

 3 . 总结分析 1). order by 只有一个reduce负责对所有的数据进行排序,若大数据量,则需要较长的时间。建议在小的数据集中使用order b...

2444
来自专栏抠抠空间

ECMAScript简介以及es6新增语法

810
来自专栏Python小白进阶之旅

Python数据类型:双端队列deque-比列表list性能更高的一种数据类型

说到容器类型,大家第一时间想到的多半是list,而list确实也能解决大部分的需要,但碰到列表内的数据量相当大的时候,性能问题就显得尤为重要;再或者列表被恶意注...

893
来自专栏desperate633

浅谈索引的优缺点和建立索引的原则

601
来自专栏鸿的学习笔记

sql解析的一些计划

关于sql解析的一些概述: 因为最近在研究如何将oracle的sql语句迁移到hive上去,前期是准备写一些udf函数去弥补hive缺失oracle函数...

602
来自专栏我的博客

数据库原理与应用【实验报告】

实验一 数据库管理系统软件的使用 一、实验目的 (1)认识几种常见的数据库管理系统,熟悉它们的使用界面; (2)熟练掌握建立数据库和表,向数据库输入数据、修改数...

3847
来自专栏算法channel

面试被问到动态内存分配时需要注意哪些坑,该怎么回答?

面试时,面试官问我们Java,Python这种语言那是必须要准确回答的,很多系统如果对性能要求高的话,底层一般会用到C/C++语言,因此被问到底层语言的相关知识...

973
来自专栏owent

VC和GCC内成员函数指针实现的研究(一)

最近在《C++对象模型》一书里说到的virtual的成员函数指针,低于128的被cfront编译器认为是虚表偏移量(支持子类对父类函数的覆盖)。VC只是提了下单...

713
来自专栏ppjun专栏

C++程序控制结构

case 后面没break 就会一直执行下去的,所以break是为了跳出switch。比如:

460
来自专栏数据小魔方

查询组合函数|index+match函数组合

今天跟大家分享的是一组查询组合函数——index+match函数组合! index和match函数是查询函数中非常厉害的组合,可以根据某单元格返回序号查找该单元...

3125

扫描关注云+社区