编码进化

回忆上次内容

  • 上次 研究了 视频终端的 演化

    • 从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
  • 分钟和秒钟

    • 逻辑类似
  • 根据 这个编码

    • 就可以 输出到

      • 当时的 输出设备

辉光钟

  • 辉光钟 是一种较为原始的 输出设备

    • 输出的结果 是10进制数字形态
    • 毕竟作为人类 读二进制数字 比较费劲
  • 12根管脚

    • 数字是几
    • 几就亮

  • 后来有了led之后

    • 出现了 seg-7
    • 七位数码管

七位数码管

  • 计算机内部

    • 得到具体二进制数字

  • 然后根据二进制数字

    • 得到数码管的led状态

  • 字型是如何生成的呢?

led编码

  • 七位数码管

    • 有7个led灯

  • 将每个灯

    • 进行编码

BCD码在今天

  • 在今天的 ascii

    • 数字字符对应的字节

      • 0x30-0x39

  • 0x30-0x39后4位 也还是 BCD编码
  • 10进制数字
    • 就是这样编码

      • 进入 二进制的计算机世界
  • 那么
    • 字母又是 怎么进入数字世界的 呢?
  • 先去总结一下BCD

总结

  • 这次 回顾了

    • 数字 进入二进制世界的 过程
  • 采用的编码是BCD
    • Binary Coded Decimal

      • 也叫8421码
      • 十进制数的 二进制形态
  • 数字的 输出形式
    • 辉光管
    • 数码管

  • 除了数字 之外

    • 还有 字母
  • 字母 是如何编码进入计算机世界的 呢?

  • 我们下次再说!

  • 蓝桥->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的更多相关文章

  1. 实验10.3_数值显示拓展_dword型数转变为表示十进制数的字符串

    assume cs:code data segment db 10 dup (0) data ends code segment start : mov ax,4240H;F4240H=1000000 ...

  2. Java中实现十进制数转换为二进制的三种思路

    Java中实现十进制数转换为二进制 第一种:除基倒取余法 这是最符合我们平时的数学逻辑思维的,即输入一个十进制数n,每次用n除以2,把余数记下来,再用商去除以2...依次循环,直到商为0结束,把余数倒 ...

  3. 栈习题(1)-对于任意的无符号的的十进制数m,写出将其转换为十六进制整数的算法(正确输出即可)

    /*对于任意的无符号的的十进制数m,写出将其转换为十六进制整数的算法(正确输出即可)*/ /* 算法思想:利用辗转取余法,每次都将余数存入栈中,直到被除数等0,退出循环. 输出栈里的内容即可 */ v ...

  4. Java中实现十进制数转换为二进制的三种方法

    第一种:除基倒取余法 这是最符合我们平时的数学逻辑思维的,即输入一个十进制数n,每次用n除以2,把余数记下来,再用商去除以2...依次循环,直到商为0结束,把余数倒着依次排列,就构成了转换后的二进制数 ...

  5. 将十进制数转为一个n位数的密码(每位都是个m进制数)

    例如一个6位数的10进制密码,共有106个密码,如果把每个6位数的密码编成号就是[0,106-1].这是十进制的情况,即6个位,每个位有10种选择.如果要遍历所有密码,需要6重for循环,每个循环10 ...

  6. 把十进制数(long型)分别以二进制和十六进制形式输出,不能使用printf系列。

    编程实现:把十进制数(long型)分别以二进制和十六进制形式输出,不能使用printf系列. 实现了unsigned long型的转换. // 十进制转换为二进制,十进制数的每1bit转换为二进制的1 ...

  7. 剑指offer—第三章高质量的代码(按顺序打印从1到n位十进制数)

    题目:输入一个数字n,按照顺序打印出1到最大n位十进制数,比如输入3,则打印出1,2,3直到最大的3位数999为止. 本题陷阱:没有考虑到大数的问题. 本题解题思路:将要打印的数字,看成字符串,不足位 ...

  8. java_十进制数转换为二进制,八进制,十六进制数的算法

    java_十进制数转换为二进制,八进制,十六进制数的算法 java Ê®½øÖÆÊýת»»Îª¶þ½øÖÆ,°Ë½øÖÆ,Ê®Áù½øÖÆÊýµÄË㕨 using System; using S ...

  9. 打印出从1到最大的n位十进制数

    首先这一题会溢出,要考虑的大数问题.所以不能用简单的是int类型数来表示(32位无符号int 范围是0x00000000···0xFFFFFFFF),下面主要是非递归的实现代码,自己做了注释方便以后回 ...

  10. 打印十进制数n 递归

    #include<stdio.h> //printd函数: 打印十进制数n void printd(int n){ ){ putchar('-'); n=-n; } ) printd(n/ ...

随机推荐

  1. 鸿蒙HarmonyOS实战-Stage模型(线程模型)

    前言 线程是计算机中的一种执行单元,是操作系统进行调度的最小单位.它是进程中的实际运行单位,每个进程可以包含多个线程.线程可以理解为进程中的一个执行流,它独立运行,拥有独立的栈和寄存器,但共享进程的资 ...

  2. Android 12(S) MultiMedia Learning(六)NuPlayer Decoder

    接下来将会从4个角度来记录NuPlayerDecoder部分 相关代码路径: http://aospxref.com/android-12.0.0_r3/xref/frameworks/av/medi ...

  3. 微信小程序设置swiper圆角在ios上失效

    今天在给轮播图添加圆角的时候,发现在安卓机上是有圆角的,但是在苹果手机上圆角却失效了,后来翻阅了文档发现这是个官方的bug 解决方法1 border-radius: 20rpx; /*再设置个tran ...

  4. k8s核心组件详解和分层架构

    k8s核心组件 master中的核心组件 api-server(接口服务,基于rest风格开放k8s接口的服务) kube-controller-manager(管理各个类型的控制器,针对k8s中的各 ...

  5. C语言常用数学函数

    目录 C语言常用数学函数(头文件#include "math.h") abs()函数 labs()函数 fabs()函数 floor()函数 floorf() floorl() c ...

  6. 算法金 | 读者问了个关于深度学习卷积神经网络(CNN)核心概念的问题

    ​大侠幸会,在下全网同名[算法金] 0 基础转 AI 上岸,多个算法赛 Top [日更万日,让更多人享受智能乐趣] 读者问了个关于卷积神经网络核心概念的问题,如下, [问]神经元.权重.激活函数.参数 ...

  7. css球体

    <!DOCTYPE html> <html lang="en"> <head>     <meta charset="UTF-8 ...

  8. react 数据请求分层

    封装一个接口请求类 数据模型 请求uri配置设置 数据统一存储于redux中,在本项目中创建一个store目录,此目录中就是redux仓库源 定义仓库入口 reducer methods方法 acti ...

  9. C#.NET Rsa私钥加密公钥解密

    在C#中,RSA私钥只能签名,不能加密,如果要加密,要借助BouncyCastle库. nuget 中引用 Portable.BouncyCastle. 工具类: RsaEncryptUtil usi ...

  10. EF,lambda 反向模糊查询

    SELECT * FROM table as t WHERE "张三的偶像" LIKE t.userName; bool thisMchBelong = _mch_blackSer ...