文章目录

  • 前言
  • 数据单位标准
    • 两种标准
  • 0x400为什么是1KB大小?
  • 回到开始的问题
  • 附录1:存储单位之间的换算
  • 附录2:常见的16进制地址及其对应容量

前言

在刚开始学习嵌入式时我们就遇到各种进制之间的换算,十六进制、十进制、八进制、二进制等等,一开始会经常在各种进制之间迷失自我;
在深入学习或者做项目或者工作时我们也经常要查看各种芯片的数据手册(datasheet),手册里面一般都是使用十六进制表示各种地址。
这时我们就会遇到类似这样的问题:

  • 为什么 0x100 是 256Bytes(字节) 大小?
  • 0x400 是 1KB 大小?
  • 0x800是 2KB 大小?

下面我们就来解决这个疑惑!

数据单位标准

我们都知道数据单位有:bit、byte、word、KB、MB、GB、TB等等,他们之间的换算很简单,例如:

 - 1TB=1024GB- 1GB=1024MB- 1MB=1024KB- 1KB=1024B(Byte)- 1B=8bit

从上面的换算我们可以不难理解下面的两个基本约定:

  • bit(比特):bit是数据的最小单位,通常简写为b。在计算机中通常用1和0来表示。
  • Byte(字节):数据存储的基本单位,通常简写为B。通常:1Byte=8bit。

但是这些都是谁规定的呢?我们得先要解决这个疑惑。

两种标准

目前,有两种比较流行的单位:一种为SI(International System of Units,国际单位制)制定的标准,采用十进制换算。例如:

1 MB = 106 bytes = 1 000 000 bytes = 1000 kilobyte
1024 MB = 1 gigabyte (GB)

其中kilo、giga等称为十进制前缀,通常简写为KB、GB等。

另一种则为IEC(International Electrotechnical Commission,国际电工委员会)于1998年2月制定的标准(IEC 60027-2),采用二进制换算。例如:

1 MiB = 2^20 bytes = 1 048 576 bytes = 1024 kibibytes
1024 MiB = 1 gibibyte (GiB)

其中kibi、gibi等称为二进制前缀,通常简写为KiB、GiB等。

下图是两种单位标准的wiki截图,摘自wiki:

IEC制定的这个标准用于在一些更严格的场景下(希望使用二进制换算的情况)替换SI的标准,目前已为大多数组织所接受,像现在的许多Linux发行版也采用这种单位。

在本文中我们只关注我们常用到的 IEC 制定的标准,所有的讨论均是在 IEC 制定的 IEC 60027-2 标准基础上。

拓展阅读:

  • https://en.wikipedia.org/wiki/Byte
  • https://simple.wikipedia.org/wiki/Mebibyte

0x400为什么是1KB大小?

为了说这个问题,我们以 2440 的芯片手册为例,下面的图是 NAND闪存映射:

下面图引用自 S3C2440A_UserManual_Rev13.pdf :p222


我们重点看 0x4000 0000 - 0x4000 0FFF 这段内存空间。图中说明这个4kb的空间是分配给BootSRAM,这个 4KB 结果的换算过程:

1. 0x4000 0FFF - 0x4000 0000 = 0x0000 0FFF
2. 0x0000 0FFF 的十进制是 4095 (Bytes)
3. (4095+1) / 1024 = 4 (KB)

为什么 0x0000 0FFF 的十进制是 4095 ,而且这就是代表 (4095+1) 个字节(也就是4KB)呢?下面我们一起来解开这个疑惑:

下图是2440的内存布局图 (0x0000 0000 - 0xFFFF FFFF)
2440的CPU是32bit的,地址总线一共有 32(2^5) 根,可以索引的地址范围是0 - 2^32 (0x0000 0000 - 0xFFFF FFFF) ,也就是 4GB 的空间。

那么这个 4GB 是怎么得来的呢?
下面的图已经给出了很直观的答案了,2440的CPU是 32 位的,所以表示的范围是:

从
0000 0000 0000 0000 0000 0000 0000 0000 (0x0000 0000)
到
1111 1111 1111 1111 1111 1111 1111 1111 (0xFFFF FFFF)

一个字节有8位,从下面的图可知,一共有 0xFFFF FFFF 个字节,也就是 4,294,967,295 个字节( 0xFFFF FFFF 转换后的十进制),所以大小为:4,294,967,295 Bytes = 4,194,305KB = 4095MB
但是这里为什么不是 4096 呢?因为我们计算的范围是 0x0000 0000 - 0xFFFF FFFF ) ,并没有算第1个字节(Byte),所以上面的应该是一共有 0xFFFF FFFF+1 个字节,也就是:4,294,967,296 Bytes = 4,194,306KB = 4096MB = 4GB

上面的案例基于 2400,其他芯片也是一样的思路分析即可。不管他是8位、16位、32位还是64位,我们只要知道他们的能表示的最大范围即可

回到开始的问题

到这里我们就能理解为什么在 2440的芯片手册中,分配给BootSRAM的 0x4000 0000 - 0x4000 0FFF 是 4KB 大小了 。

那么我们来解决一开始提出的问题: 为什么0x400是1KB大小?

0x400转换的十进制为:1024,也就是有 1024 个字节(Byte),
1KB的换算过程:1024(Byte)/1024=1kb

用这种思路我们就可以理解为什么, 0x100 是 256 个字节(Bytes)、0x800是 4096 个字节(Bytes)也就是 4KB。

附录1:存储单位之间的换算

1 Byte(B) 8 bit
1 Kilo Byte(KB) 1024B
1 Mega Byte(MB) 1024 KB
1 Giga Byte (GB) 1024 MB
1 Tera Byte(TB) 1024 GB
1 Peta Byte(PB) 1024 TB
1 Exa Byte(EB) 1024 PB
1 Zetta Byte(ZB) 1024 EB
1Yotta Byte(YB) 1024 ZB
1 Bronto Byte(BB) 1024 YB
1Nona Byte(NB) 1024 BB
1 Dogga Byte(DB) 1024 NB
1 Corydon Byte(CB) 1024DB
1 Xero Byte (XB) 1024CB

附录2:常见的16进制地址及其对应容量

十六进制 大小
0x100 256B
0x200 512B
0x400 1KB
0x800 2KB
0xC00 3KB
0x1000 4KB
0x2000 8KB
0xF000 60KB
0x1 0000 64KB
0x2 0000 128KB
0xF 0000 960KB
0x10 0000 1MB
0x20 0000 2MB
0xF0 0000 15MB
0x0100 0000 16MB
0x0200 0000 32MB
0x0F00 0000 240MB
0x1000 0000 256MB

【嵌入式基础】为什么0x100是256个字节、0x400是1KB、0x800是2KB、0x1000是4KB?相关推荐

  1. 为什么0x100是256个字节、0x400是1KB、0x800是2KB、0x1000是4KB?

    文章目录 前言 数据单位标准 两种标准 0x400为什么是1KB大小? 回到开始的问题 附录1:存储单位之间的换算 附录2:常见的16进制地址及其对应容量 前言 在刚开始学习嵌入式时我们就遇到各种进制 ...

  2. 嵌入式基础(1)---硬件知识,搞嵌入式开发必备

    嵌入式基础硬件知识,搞嵌入式开发必备 做嵌入式系统开发,经常要接触硬件.做嵌入式开发对数字电路和模拟电路要有一定的了解. 这样才能深入的研究下去.下面我们简单的介绍嵌入式开发中的一些硬件相关的概念. ...

  3. 嵌入式系统概念以及嵌入式基础知识

    嵌入式系统概念以及嵌入式基础知识 \\\插播一条:我自己在今年年初录制了一套还比较系统的入门单片机教程,想要的同学找我拿就行了免費的(禾厶-亻言-手戈).最近比较闲,带做毕设,带学生参加省级以上比赛/ ...

  4. STM32嵌入式基础开发附C-STM32-CAN通讯

    目录 1 博客内容 2 STM32芯片.TJA1050.上位机 3 CAN环回模式.轮询/中断接收模式 4 程序原理 5 主程序(Main.c) 6 CAN程序(CAN.c) 7 CAN头文件(CAN ...

  5. 应邀ITGeGe在线教育社区嵌入式基础开发讲师

    最近,被一家IT在线公司邀请去做嵌入式基础课程的讲师,我感觉非常荣幸,虽然我还是菜鸟一个,难得有这样的企业会看得起我,这也是对我的一个磨练吧,可以培养我继续不断学习技术的动力,同时还能将技术通过自身的 ...

  6. matlab中三相断路器如何连接,Matlab在电力电子技术仿真中的应用 - 嵌入式基础教程...

    Matlab在电力电子技术仿真中的应用 - 嵌入式基础教程 (2017-06-07 11:51:26) 1. 引言 20世纪60年代发展起来的电力电子技术,使电能可以变换和控制,产生了现代各种高效.节 ...

  7. ChinaSoft 论坛巡礼 | 嵌入式基础软件论坛

    2022年CCF中国软件大会(CCF ChinaSoft 2022)将于2022年11月25-27日在线上举行.预期将有林惠民.陈左宁.邬江兴.何积丰.梅宏.吕建.柴洪峰.廖湘科.王怀民.郑纬民.蒋昌 ...

  8. 整数边界对齐方式_嵌入式基础——字节对齐

    字节对齐 一.内存访问对齐规则 从高级语言的视角看,内存访问是是字节为单位的. 但是从CPU角度看,内存访问粒度与指令有关,比如1字节访问,2字节访问,4字节访问,8字节访问等. 如果在编程过程中不注 ...

  9. Linux嵌入式基础知识

    一个嵌入式Linux系统从软件的角度看通常可以分为四个层次: 1. 引导加载程序:包括固化在固件(firmware)中的boot代码(可选),和BootLoader两大部分. 2.Linux内核:特定 ...

最新文章

  1. GAN是一种特殊的损失函数?
  2. 7系列高速收发器总结 GTP IP核使用篇
  3. 设为首页加入收藏代码
  4. python发邮件11002_Python学习笔记(二)——数字类型的运算及其输入与格式化输出...
  5. boost::hana::zip用法的测试程序
  6. Blogger建立Blog部落格​​ - Blog透视镜
  7. group count聚集函数无法直接统计出分组后的总记录数
  8. poj 1035 Spell checker(hash)
  9. 《Ray Tracing in One Weekend》——Chapter 12: What's next?
  10. DEV控件之ChartControl用法
  11. 微处理器系统结构与嵌入式系统设计(一)
  12. 奥克兰大学计算机科学与技术,奥克兰大学计算机科学专业怎么样?成为IT达人就靠它...
  13. Arduino框架下调试STM32F103C8T6
  14. python 以毫秒为单位计时
  15. Android:空气质量检测界面(布局嵌套),练手推荐。
  16. 计算机网络系统不可用,网络连接不可用,小编教你电脑网络连接不可用怎么办...
  17. (solved)[/usr/bin/python2: No module named pip]
  18. ssh登录极路由后台_使用SSH来远程使用服务器上的可视化软件
  19. [生命科学] 生物基础实验之PCR验证
  20. WindbgX64和WinxpSp3虚拟机双击调试的参数设置

热门文章

  1. 数学连乘和累加运算符号_(前n项和积)一道数列累加法和累乘法巧妙结合的题目...
  2. python游戏的好处和坏处_游戏的好处和坏处
  3. 使用Exchange同步联系人/日历/邮件
  4. 说说我的显卡购买心得~
  5. java模板方法模式_JAVA 设计模式 模板方法模式
  6. Linux 虚拟机和主机互通 [万能方法]
  7. 秒杀的性能问题和超卖
  8. 国外通过3D打印技术设计微型装置,让我们再也不用担心用水安全
  9. PAT甲级考试知识点总结和一些看法
  10. 图解“互联网大脑”与“互联网+”