8位2进制数用16进制表示后 00H~FFH 那个H是什么意思??

kuaidi.ping-jia.net  作者:佚名   更新日期:2024-06-28
单片机的数据存储器RAM地址空间为00H~FFH,其中00H~FFH是什么意思,H,F分别代表什么

H表示是16进制数,16进制数中用0—9和A—F来表示十进制数的0—15,一位16进制数最多可以表示16个数,即0H—FH,F则相当于15。

在单片机里,储存空间划分成很多小单元,每个单元包含8个2进制位,即一个字节。每个单元都给一个地址标号,相当于门牌号,从0开始。你的这个单片机Ram地址空间00H—FFH,化成10进制数就是0—255,共256字节,不出意外的话,你那个是典型的51单片机。

hex的缩写,表示前面的这个是一个16进制数。00H就是16进制的00。不然单给一个10谁也不知道他是2进制,10进制,16进制还是其他的一些什么

16进制
也就是基本数字由0123456789变成了
0123456789ABCDEF
这里的H是16进制的一个缩写而已
H:十六进制(英文名称:Hexadecimal),是计算机中数据的一种表示方法。同我们日常生活中的表示法不一样。它由0-9,A-F组成,字母不区分大小写。与10进制的对应关系是:0-9对应0-9;A-F对应10-15;N进制的数可以用0~(N-1)的数表示,超过9的用字母A-F。
16进制的20表示成10进制就是:2×16¹+0×16º=32
10进制的32表示成16进制就是:20
十进制数可以转换成十六进制数的方法是:十进制数的整数部分“除以16取余”,十进制数的小数部分“乘16取整”,进行转换。
比如说十进制的0.1转换成八进制为0.0631463146314631。就是0.1乘以8=0.8,不足1不取整,0.8乘以8=6.4,取整数6, 0.4乘以8=3.2,取整数3,依次下算。
编程中,我们常用的还是10进制.毕竟C/C++是高级语言。
比如:
int a = 100,b = 99;
不过,由于数据在计算机中的表示,最终以二进制的形式存在,所以有时候使用二进制,可以更直观地解决问题。但二进制数太长了。比如int 类型占用4个字节,32位。比如100,用int类型的二进制数表达将是:

0000

0000

0000

0000

0110

0100

面对这么长的数进行思考或操作,没有人会喜欢。因此,C,C++ 没有提供在代码直接写二进制数的方法。用16进制或8进制可以解决这个问题。因为,进制越大,数的表达长度也就越短。不过,为什么偏偏是16或8进制,而不其它的,诸如9或20进制呢?2、8、16,分别是2的1次方、3次方、4次方。这一点使得三种进制之间可以非常直接地互相转换。8进制或16进制缩短了二进制数,但保持了二进制数的表达特点。

B:二进制
D:十进制(默认不写)
O:八进制
H:十六进制

你以后见到了要自己区分

这是基本知识

是一种习惯性的后缀写法,用以说明这个数字的进制。带B说明是2进制,H表示16进制数。