- 1
- 0
- 约8.63千字
- 约 14页
- 2023-07-12 发布于上海
- 举报
为什么需要八进制和十六进制?
编程中,我们常用的还是 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 进制缩短了二进制数,但保持了二进制数的表达特点。在下面的关于进制转换的课程中,你可以发现这一点。
二、八、十六进制数转换到十进制数
二进制数转换为十进制数
二进制数第 0 位的权值是 2 的 0 次方,第 1 位的权值是 2 的 1 次方…… 所以,设有一个二进制数:0110 0100,转换为 10 进制为:
下面是竖式:
0110 0100 换算成 十进制
第 0 位
0
*
原创力文档

文档评论(0)