[oeasy]python0083_十进制数如何存入计算机_八卦纪事_BCD编码_Binary_Coded_Decimal
编码进化
回忆上次内容
- 上次 研究了 视频终端的 演化
- 从VT05 到 VT100
- 从 黑底绿字 到 RGB 24位真彩色
- 形成了 VT100选项
- 从而 将颜色
数字化
了
- 生活中我们更常用 10个数字
- 但是 计算机中 用二进制
- 日常计数的十进制数
- 是如何存储进计算机的呢?
从10进制到2进制
- 日常生活中 为什么用10进制?
- 是因为 人的生理结构
- 计算机中 使用2进制
- 是因为 计算机的生理结构
- 电灯、开关等电器 有两种状态
- 是因为 计算机的生理结构
- 先回顾一下 之前编码的 历史
编码
- 编码是 绞丝旁的
- 可以追溯 到有 文字之前
- 结绳 为约
- 事大 大结其绳
- 事小 小结其绳
- 上古 结绳而治
- 后世圣人 易之以书契
八卦
- 事 都往绳子上 系
- 记住数字 到底是几
- 在绳子上 系住了
- 这事情就算是 记住了
- 留下了 纪录
- 以后把绳子 挂出来
- 进行 比较、判断
- 这就是 卦
- 经典的卦
- 三个 位置
- 可以表示 八种状态
- 事情
- 都在这八种模式下
- 普遍联系
- 千变万化
- 这就是八卦
- 现代数字 如何编码 呢?
编码格式 演化
- 最早电报时代
- 数字编码 是 摩斯电码
- 右下角
- 是数字的 编码
- 长短空
- 全靠发报人
- 掌握节奏
- 控制波特率
- 全靠发报人
- 每个人 都是
- 自己人工 编码解码
- 然后进入到
- 电传打字机时代
博多码
电传打字机 编码
- 只有两种状态
- 0
- 1
- 有控制字符
- Letter
- Figure
- 只有两种状态
Figure 包含数字
- 这些编码
- 可以 存储在 纸带上
- 只有大写 没有小写
- 符号 不是很丰富
- 是一种 5-bit 的编码
ibm 的企图心
- 1790s 末
- ibm 的前身
- 拿到了 美国人口统计局的 巨大订单
- 在此之前
- 无论是身份、存款、地产靠的都是纸质的契约
- 计算机刚刚起步
- 更没有相互联通的数据中心了
- ibm想要用计算机进行统计
- 当时用的是 采集卡片
- 就是去 挨家挨户的 问人家
- 然后 打卡片打孔
- 在当年
上门查户口
是很明显的冒犯
年龄
- 这统计里面涉及到 统计
计数
- 有数字
- 就可以对 性别、年龄、地区
分类汇总
- 而且要 显示出来
- 这纸带上 有很多位置
- 要么是 打了孔
- 要么是 没打孔
二进制
- 打孔卡 本质上是
- 一种二进制的 存储方式
- 通过探针 访问这些打卡孔
- 可以得到 当前位置上 二进制的值
- 想要表示
10
个数字字符的 话?- 要使用 多少位
2进制数
呢?
- 要使用 多少位
编码十个数目字
- 想要把 10个数字 都编码
- 3位 2进制数 不够
- 至少 4位 2进制数
- 就算有了 4位二进制数
- 究竟如何 编码 呢?
标准 纷争
- 同样是表示 10个数字
- 有不同的 编码方式
- 不同编码 表示的范围 也不一样
- 有的是 为了表示的数字 更多
- 有的是 为了可以表示负数
- 还有的是 为了加密
- 各种编码之间转化 也需要成本
- 为了数据 交换方便
- 编码 还是得
统一
- 到底统一到 什么编码方式 呢?
BCD码
- 最终 统一的编码
- BCD码
- Binary Coded Decimal
- 8421码
- 这个其实比较好理解
- 使用的是 十进制数字
- 对应的 二进制数 形态
- BCD码 就叫 8421码
- 四位 分别代表 8、4、2、1
8421码
- 最终数字领域的 编码统一到
- BCD码
- Binary-Coded Decimal
- 也叫8421码
- 用最简单的 编码方式实现了 统一
8421
点明了 每位二进制数- 对应的数值
- 这种 编码
- 其实 就是
- 纯纯的
2进制数
形态
- 纯纯的
- 其实 就是
数字表示
- 下图中HMS的个位数字 就是 8421编码
- 从上到下 总共4个二进制位
- 分别代表8421
- 竖着一溜 就是一个数字
小时H 总共两位
- H十位
- 最大的小时数 为24
- 十位数值 不会超过2
- 所以 两位就够
- 两位二进制数可 以表示0-3
- 数值为(0)×20+(1)×20 = 1
- H个位
- 最大的数字就是9
- 不会超过10
- 总共需要4位
- 数值为(0)×20+(0)×20 = 0
- 小时的 总体数值为10
- H十位
分钟和秒钟
- 逻辑类似
根据 这个编码
- 就可以 输出到
- 当时的 输出设备
- 就可以 输出到
辉光钟
辉光钟 是一种较为原始的 输出设备
- 输出的结果 是10进制数字形态
- 毕竟作为人类 读二进制数字 比较费劲
12根管脚
- 数字是几
- 几就亮
- 后来有了led之后
- 出现了 seg-7
- 七位数码管
七位数码管
- 计算机内部
- 得到具体二进制数字
- 然后根据二进制数字
- 得到数码管的led状态
- 字型是如何生成的呢?
led编码
- 七位数码管
- 有7个led灯
- 将每个灯
- 进行编码
BCD码在今天
- 在今天的
ascii
中- 数字字符对应的字节
- 是
0x30-0x39
- 是
- 数字字符对应的字节
0x30-0x39
的后4位
也还是 BCD编码- 10进制数字
- 就是这样编码
- 进入 二进制的计算机世界
- 就是这样编码
- 那么
- 字母又是 怎么进入数字世界的 呢?
- 先去总结一下BCD
总结
- 这次 回顾了
- 数字 进入二进制世界的 过程
- 采用的编码是BCD
- Binary Coded Decimal
- 也叫8421码
- 十进制数的 二进制形态
- Binary Coded Decimal
- 数字的 输出形式
- 辉光管
- 数码管
除了数字 之外
- 还有 字母
字母 是如何编码进入计算机世界的 呢?
我们下次再说!
蓝桥->https://www.lanqiao.cn/courses/3584
github->https://github.com/overmind1980/oeasy-python-tutorial
gitee->https://gitee.com/overmind1980/oeasypython
视频->https://www.bilibili.com/video/BV1CU4y1Z7gQ 作者:oeasy
[oeasy]python0083_十进制数如何存入计算机_八卦纪事_BCD编码_Binary_Coded_Decimal的更多相关文章
- 实验10.3_数值显示拓展_dword型数转变为表示十进制数的字符串
assume cs:code data segment db 10 dup (0) data ends code segment start : mov ax,4240H;F4240H=1000000 ...
- Java中实现十进制数转换为二进制的三种思路
Java中实现十进制数转换为二进制 第一种:除基倒取余法 这是最符合我们平时的数学逻辑思维的,即输入一个十进制数n,每次用n除以2,把余数记下来,再用商去除以2...依次循环,直到商为0结束,把余数倒 ...
- 栈习题(1)-对于任意的无符号的的十进制数m,写出将其转换为十六进制整数的算法(正确输出即可)
/*对于任意的无符号的的十进制数m,写出将其转换为十六进制整数的算法(正确输出即可)*/ /* 算法思想:利用辗转取余法,每次都将余数存入栈中,直到被除数等0,退出循环. 输出栈里的内容即可 */ v ...
- Java中实现十进制数转换为二进制的三种方法
第一种:除基倒取余法 这是最符合我们平时的数学逻辑思维的,即输入一个十进制数n,每次用n除以2,把余数记下来,再用商去除以2...依次循环,直到商为0结束,把余数倒着依次排列,就构成了转换后的二进制数 ...
- 将十进制数转为一个n位数的密码(每位都是个m进制数)
例如一个6位数的10进制密码,共有106个密码,如果把每个6位数的密码编成号就是[0,106-1].这是十进制的情况,即6个位,每个位有10种选择.如果要遍历所有密码,需要6重for循环,每个循环10 ...
- 把十进制数(long型)分别以二进制和十六进制形式输出,不能使用printf系列。
编程实现:把十进制数(long型)分别以二进制和十六进制形式输出,不能使用printf系列. 实现了unsigned long型的转换. // 十进制转换为二进制,十进制数的每1bit转换为二进制的1 ...
- 剑指offer—第三章高质量的代码(按顺序打印从1到n位十进制数)
题目:输入一个数字n,按照顺序打印出1到最大n位十进制数,比如输入3,则打印出1,2,3直到最大的3位数999为止. 本题陷阱:没有考虑到大数的问题. 本题解题思路:将要打印的数字,看成字符串,不足位 ...
- java_十进制数转换为二进制,八进制,十六进制数的算法
java_十进制数转换为二进制,八进制,十六进制数的算法 java Ê®½øÖÆÊýת»»Îª¶þ½øÖÆ,°Ë½øÖÆ,Ê®Áù½øÖÆÊýµÄË㕨 using System; using S ...
- 打印出从1到最大的n位十进制数
首先这一题会溢出,要考虑的大数问题.所以不能用简单的是int类型数来表示(32位无符号int 范围是0x00000000···0xFFFFFFFF),下面主要是非递归的实现代码,自己做了注释方便以后回 ...
- 打印十进制数n 递归
#include<stdio.h> //printd函数: 打印十进制数n void printd(int n){ ){ putchar('-'); n=-n; } ) printd(n/ ...
随机推荐
- 基于webapi的websocket聊天室(三)
上一篇处理了超长消息的问题.我们的应用到目前为止还是单聊天室,这一篇就要处理的多聊天室的问题. 思路 第一个问题,怎么访问不同聊天室 这个可以采用路由参数来解决.我把路由设计成这样/chat/{roo ...
- 大数据之Hadoop集群中Yarn常用命令
Yarn状态的查询,除了可以在hadoop103:8088页面查看以外,还可以通过命令操作.常见的命令操作如下所示. 需求:执行WordCount案例,并通过Yarn命令查看任务运行情况.原文:sw- ...
- MySQL知识网络
MySQL知识网络 引擎 InnoDB 支持表锁 .行锁 支持事务 *.frm 表结构文件 *.idb 表数据和索引文件 MyISAM 支持表锁 *.frm 表结构文件 *.MYD 表数据文件 *.M ...
- P1746 离开中山路
传送锚点:https://www.luogu.com.cn/problem/P1746 题目背景 <爱与愁的故事第三弹·shopping>最终章. 题目描述 爱与愁大神买完东西后,打算坐车 ...
- 记一次 .NET某企业数字化平台 崩溃分析
一:背景 1. 讲故事 前些天群里有一个朋友说他们软件会偶发崩溃,想分析看看是怎么回事,所幸的是自己会抓dump文件,有了dump就比较好分析了,接下来我们开始吧. 二:WinDbg 分析 1. 程序 ...
- 如何判断7z压缩文件格式
如果压缩文件的后缀不是7z,那么如何如何判断文件格式呢?那就是通过文件头判断. 7z文件头前6位,固定是:377ABCAF271C,其中前两位37.7A分别是"7""z& ...
- (拼多多)pdd的Anti-Content
声明 本文章中所有内容仅供学习交流,抓包内容.敏感网址.数据接口均已做脱敏处理,严禁用于商业用途和非法用途,否则由此产生的一切后果均与作者无关,若有侵权,请联系我立即删除! 目标网站 aHR0cHM6 ...
- xpath提取不到值(iframe嵌套)的问题
爬取http://xgj.xiangyang.gov.cn/zwgk/gkml/?itemid=2471的时候遇到frame嵌套,内部的a标签获取不到. 网上也有人遇到了同样的问题.https://b ...
- ETL工具-nifi干货系列 第十七讲 nifi Input Port&Out Port 实战教程
1.端口(Port),包含输入端口(Input Port)和输出端口(Out Port ) 使用一个或多个处理组构建的数据流需要一种方式将处理组连接到其他数据流组件. 处理组和处理组之间可以通过使用端 ...
- ABC339
题解不应该流露出太多感情,对吧. E 建议评黄. 首先我们可以想到暴力 dp. 定义 \(dp_i\) 为以 \(a_i\) 为结尾满足题目意思的最长序列的长度. 很明显,时间复杂度为 \(O(n^2 ...