编码进化

回忆上次内容

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

    • 从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. js 数组按指定字段转map-list结构

    js 数组按指定字段转map-list结构 背景介绍 在开发过程中经常会出现接口返回整个数组,我们需要将数组进行二次处理,如下格式按照不同功能模块(type)进行数据拆分 原始数据 const lis ...

  2. RocketMQ主从同步原理

    一. 主从同步概述 主从同步这个概念相信大家在平时的工作中,多少都会听到.其目的主要是用于做一备份类操作,以及一些读写分离场景.比如我们常用的关系型数据库mysql,就有主从同步功能在. 主从同步,就 ...

  3. AI实战 | 手把手带你打造校园生活助手

    大家好,我是努力的小雨.最近,我开始将我的经验逐渐分享到B站,希望能够帮助大家通过扣子助手真正解决一些问题.最近有粉丝提出了一个需求,为了满足大家的期待,我已经制作了视频,详细介绍了这个助手的搭建思路 ...

  4. Android 13 - Media框架(32)- ACodec(八)

    关注公众号免费阅读全文,进入音视频开发技术分享群! 拖了好久都没有更新,前面写的东西都有些忘了,回过头来再看之前写的内容,觉得有很多地方写的不好,或者说现在又有了新的理解,想要重新修改但是需要修改的内 ...

  5. zabbix笔记_001

    zabbix介绍 zabbix是一个基于WEB界面的提供分布式系统监视以及网络监视功能的企业级的开源解决方案. zabbix能监视各种网络参数,保证服务器系统的安全运营:并提供灵活的通知机制以让系统管 ...

  6. 算法金 | 详解过拟合和欠拟合!性感妩媚 VS 大杀四方

    大侠幸会,在下全网同名「算法金」 0 基础转 AI 上岸,多个算法赛 Top 「日更万日,让更多人享受智能乐趣」 今天我们来战 过拟合和欠拟合,特别是令江湖侠客闻风丧胆的 过拟合,简称过儿, Emmm ...

  7. itest(爱测试) 接口测试,敏捷测试管理平台 10.4.0 发布

    一:itest work 简介 itest work 开源敏捷测试管理,包含极简的任务管理,测试管理,缺陷管理,测试环境管理,接口测试,接口Mock,还有压测 ,又有丰富的统计分析,8合1工作站.可按 ...

  8. 安装图形化界面时候报错 Transaction check error: file /boot/efi/EFI/centos from install of fwupdate-efi-12-5.el7.centos.x86_64 conflicts with file from package grub2-common-1:2.02-0.65.el7.centos.2.noarch

    报错 Transaction check error:file /boot/efi/EFI/centos from install of fwupdate-efi-12-5.el7.centos.x8 ...

  9. GNU GDB

    1 说明 本文主要介绍一些简单的.常用的gdb调试技巧. 环境:GNU gdb (GDB) Red Hat Enterprise Linux (7.2-60.el6_4.1) 参考文档:<gdb ...

  10. 数据库系列16:MyISAM与InnoDB的索引对比

    相关文章 数据库系列:MySQL慢查询分析和性能优化 数据库系列:MySQL索引优化总结(综合版) 数据库系列:高并发下的数据字段变更 数据库系列:覆盖索引和规避回表 数据库系列:数据库高可用及无损扩 ...