《编码:隐匿在计算机软硬件背后的语言(Code:The Hidden Language of Computer Hardware and Software)》读书笔记

声明

该文章是阅读《编码:隐匿在计算机软硬件背后的语言》一书之后整理出的读书笔记。若有错误,还需继续修正与增删。


Preface

作者Charles Petzold是Windows编程界的大师,当今世界顶级技术作家。
他是WindowsGDI程序设计首席技术作家,其大作Programming Windows(Windows程序设计)是尽人皆知的Windows编程经典。

What?本书讲了什么

这是一本讲述计算机工作原理的书。读者可以通过本书获得对计算机工作原理较深刻的理解这种理解的深度不逊于*“电气工程师”“程序员”*的理解。

How? 本书是怎样讲的

一系列被有机结合起来的零星知识,所涉及的问题包括计算机体系结构、汇编语言及数字电子技术等。

  • 历史角度:审视了计算机技术的发展脉络
  • 自底向上:导线、灯泡以及触发器等简单部件通过精妙地组装,可以构建出一台电子计算机
  • 旁征博引:从美国当红影评人到百年前的布莱叶盲文,从史密斯·索尼亚的滑尺到冯·诺依曼的构想,从石破天惊的论文《思维之际》到图形化革命

When?计算机发展时间线

Created with Raphaël 2.2.0 差分机的设想(查尔斯·巴贝芝,1820) 布莱叶盲文(路易斯·布莱叶,1824) 解析机的设想(查尔斯·巴贝芝,1833) 莫尔斯码(塞缪尔·莫尔斯,1837) 第一条电报线路架设完成(萨缪尔·莫尔斯,1844) 这是现代通信开始的标志 《形式逻辑》(Formal Logic)发表(摩根,1847) 《思维规律》发表(乔治·布尔,1854) 数学描述逻辑的方法出现——布尔代数 波多电传码诞生(埃米尔·波多,1874) 美国人口普查中,霍尔瑞斯穿孔卡片取得成功(赫尔曼·霍尔瑞斯,1890) 制表机公司创立(赫尔曼·霍尔瑞斯,1896) 制表机公司更名为C-T-R公司(1911) 触发器被发明(威廉姆·亨利·艾克里斯与F.W.乔丹,1918) C-T-R公司更名为国际商业机器公司(IBM)(托马斯 J·华盛顿,1924) 第一台继电器数字计算机建造完成(康拉德·楚泽,1935) 图灵机模型提出(艾伦·M·图灵,1937) 复数计算机诞生(贝尔实验室,1939) 真空管被广泛应用(弗莱明与福雷斯特,20世纪40年代) 第一台自动连续可控计算机(ASCC)Harvard Mark I诞生(霍华德·艾肯,哈佛大学与IBM,1943) 巨像(Colossus)计算机破译德国的“Enigma””代码生成器产生的代码(艾伦·M·图灵,1943) 真空管作为第一台电子计算机的基础,完全取代继电器(1945) 使用了18,000个真空管,大约30吨重的电子数字积分计算机(ENIAC)诞生(埃克特与莫克利,1945) 《思维之际(As We May Think》文章发表(万·布什,1945) 包含“存储程序概念”理念的“冯·诺依曼结构”被提出(约翰·冯·诺依曼等,1946) 晶体管问世(巴丁与布兰坦,1947) bit单词被创造表示二进制数(约翰·威尔德·特克,1948) “通信过程中的代数理论”被发表,信息论研究领域开创(克劳德·香农,1948) “控制论”提出(诺博尔特·韦纳,1948) 图灵测试法提出(艾伦·M·图灵,1950) 第一台商用计算机——通用自动计算机(UNIVAC)诞生(埃克特与莫克利计算公司,1951) 第一个编译器A-0完成(格瑞斯·穆雷·霍珀,1952) IBM 704第一次将浮点数运算硬件作为可选配件(IBM公司,1954) FORTRAN开发(IBM公司,20世纪50年代中期) “磁芯存储器”被开发出(20世纪50年代中期) 字节(byte)被创造(IBM公司,1956) 肖克利半导体实验室在加利福尼亚帕罗奥图市成立,当今硅谷所在地区(威廉·肖克利,1956) 首款磁盘驱动器RAMAC发明(IBM公司,1956) 集成电路被发明(杰克·基尔比与罗伯特·诺依斯,1958-1959) COBOL面世(1959) ALGOL改进版面世(1960) PL/I面世(IBM公司,20世纪60年代中期) BASIC面世(约翰·克莫尼与托马斯·克鲁兹,1964) 摩尔定律提出(戈登·E·摩尔,1965) ASCII码正式公布(1967) Pascal面世(尼尔莱斯·沃思,20世纪60年代末) 使用集成电路在一块电路板上制造一个完整的计算机处理器变得可能(20世纪70年代早期) 第一块芯片诞生(英特尔公司,1970) 第一块“计算机芯片(微处理器)”Intel 4004诞生(英特尔公司,1971) UNIX操作系统开发(肯·汤普森与丹尼斯·里奇,贝尔实验室,20世纪70年代初) C面世,同年UNIX采用C语言编写成功(丹尼斯·M·里奇,1973) 两种典型的微处理器:Intel 8080与Motorola 6800推出(1974) 第一台家用电脑Altair 8800出现(1975) 为Altair 8800编写了BASIC解释器,同年微软公司创建(比尔·盖茨与保罗·艾伦,1975) Apple II推出(斯蒂夫·乔布斯与史蒂芬·沃茨内卡,苹果计算机公司,1977) PARC的Alto项目取得成果,图形用户界面(GUI)登上历史舞台(20世纪70年代晚期) IBM第一代PC诞生,MS-DOS成为第一代个人计算机的操作系统(IBM公司,1981) 苹果公司推出麦金托什机(Macintosh),同年苹果操作系统(Mac OS)诞生(斯蒂夫·乔布斯,1984) 几大著名计算机公司合作研究出统一化字符编码标准Unicode(1988) Windows 3.0发布,世界瞩目(微软公司,1990) Intel奔腾系列微处理器推出(英特尔公司,1993)

How?自底向上的计算机结构

发展
连接
底层
灯泡
电线
开关
继电器
缓冲器 反向器 逻辑门
加法器
振荡器
触发器
8-1选择器
3-8译码器
16位计数器
8位锁存器
8x1RAM阵列
64Kx8RAM阵列
控制面板
累加器
输出设备
输入设备
存储器
处理器
算术逻辑单元
电子计算机

文章目录

Body

1. 至亲密友

编码是一种用来在机器和人之间传递信息的方式。编码就是交流。

What?各类编码
  • 莫尔斯电码(Morse Code)
  • 口头话语(the spoken word)或言辞(speech)
  • 书面语言(the written word)或文本(text)
  • 手语
  • 布莱叶盲文(Braille)
AD&DAD:莫尔斯编码
  • DAD:
  1. 莫尔斯编码没有区分大写字母和小写字母
  • AD:
  1. 证明了两个不同的事物只要经过适当的组合,即可表示所有类型的信息。

2. 编码与组合

莫尔斯码又称二进制码(Binary Code),它的组成元素只有两个——“点”和“划”。点、划的组合可以表示你想要的任意数目的码字。

码 字 的 数 目 = 2 “ 点 ” 和 “ 划 ” 的 数 目 = 2 编 码 的 位 数 码字的数目 = 2^{“点”和“划”的数目}=2^{编码的位数} =2=2


3. 布莱叶盲文与二进制码

布莱叶盲文的工作方式 ——> 编码的一些性质

DIF:瓦伦丁·霍伊与路易斯·布莱叶
  • 视力健全的人被自身的感知模式所禁锢。(类似于手电筒交流在空中比划字母的形状)
  • 完全不同于印刷字母的文字系统更适合盲人阅读。
AD:布莱叶盲文
  1. 缩写:二级布莱叶盲文
  2. 优先码(precedence codes)或换档码(shift codes):数字标识符与字母标识符(作用域内,直到作用域结束)
  3. 逃逸码:大写标识符(可区分大小写,紧随其后的字母)

4. 手电筒的剖析

电在计算机中的工作原理——电学

What?电学知识
  • 串联与并联
  • 导电性与阻抗性,导体与绝缘体
  • 电阻(阻抗)的影响因素
  • 电压、电流、电阻和功率
  • 开关(很重要的部分

二进制码与电气电路之间的相似性将起到很大作用。


5. 绕过拐角的通信

电路

How?铺设长电路时处理大电阻
  • 使用粗导线(昂贵)
  • 增加电压,同时使用更大电阻的灯泡
PRO:由于电阻的存在电路距离跨度不能实现无限(如电报系统)

Solution:继电器


6. 电报与继电器

今天的全球性即时通信融合了两点:即时通信与远距离通信。在19世纪早期,为了实现以上两点的融合,电报以及继电器应运而生。

How?电报机(telegraph)的相关问题
  • 在线路的这一段采取一些措施,使线路的另一端发生某种变化
  • 电磁现象(电磁铁)
  • 长导线所带来的电阻:线路不能无限延长——>中继系统
  • 继电器:输入弱电流,输出强电流

7. 我们的十个数字

十进制

  • Digit:数字,手指、脚趾
  • five与fist(拳头)具有相同的词根
AD&DAD:罗马数字系统(古希腊人并不以代数著称)
  • DAD:
  1. 不易于乘除
  • AD:
  1. 易于加减
AD:印度-阿拉伯数字系统(位置计数系统)
  1. 位置相关
  2. 没有10的符号
  3. 有0

8. 十的替代品

其它进制,八进制、四进制、二进制。


9. 二进制数

二进制中的一位(bit)称为1比特,我们可用它表达简单的信息:是或不是,亮或灭,打开或关闭。而事实上只要信息能转换成两种或多种可能性的选择,都可以用比特来表示(胶卷的胶片速度、条形码)。


10. 逻辑与开关

布尔代数:一种数学形式来描述逻辑

DIF:布尔代数与传统代数
  • 布尔代数中,加法也可以分配乘法
  • 最大区别
    F ∗ F = F F*F=F FF=F
    F + F = F F+F=F F+F=F
What?布尔测试
AND01
000
101
OR01
001
111
NAND01
011
110
NOR01
010
100
XOR01
001
110
What?重要的概念突破——将布尔代数与电路相融合

串 联 = A N D 串联=AND =AND
并 联 = O R 并联=OR =OR

  • 乔治·布尔没有机会观察布尔表达式在开关线路与如何实现(布尔去世后15年人类才发明白炽灯)。
  • 在19世纪,没有人将布尔代数中的AND与OR同线路中的串联及并联关联到一起。

11. 门

逻辑门(logic gate):继电器的组合,用电路去模拟基本逻辑任务

What?继电器的连接——逻辑门的关键
  • 四种基本逻辑门
    • 与门 AND
    • 或门 OR
    • 或非门 NOR
    • 与非门 NAND
    • 异或门 XOR
  • 复杂电路
    • 2-4译码器
  • 反向器(inverter)
  • 缓冲器(buffer) 没什么作用
What?摩根定律
  • 两组等价关系
  • 简化布尔表达式的重要手段(简化电路

12. 二进制加法器

搭建计算两个数加和的器件是搭建一台计算机的基础。

What?逻辑门与二进制加法的相关性
+加法01
001
110
+进位01
000
101
  • 进位位与与门的输出结果一致
  • 加法位与异或门的输出结果一致

半加器(Half Adder)(没有将之前一次加法可能产生的进位位纳入下一次运算)
全加器(Full Adder)(包括进位输入)


13. 如何实现减法

加法和减法在某些方面互相补充,但是在机制上二者却存在本质区别 ——> 把减法变成加法

How?如何解决减法中的借位问题

利用补数,我们将不会再用到减法。(以1开头的每个二进制数都表示一个负数)

How?求2的补数
  • 将每位取反再加1
  • 相同方法可还原数值

有符号数与无符号数


14. 反馈与触发器

记忆力:一个能计数的电路必定需要触发器。

What?振荡器
  • 不需要人为干涉,自发工作
  • 时钟(clock)
  • 循环(cycle)、周期(period)、频率(frequency)
What?反馈(feedback)
  • 当两个开关都断开时,两个稳定态——**触发器(Flip-Flop)**可以保持信息
  • 一个能计数的电路必定需要触发器——计数器
  • R-S触发器
  • 电平触发与边沿触发时钟

15. 字节与十六进制

8位的数据流,即数据路径的位宽为8。


16. 存储器组织

存储器:记录信息

  • D型电平触发器——>锁存器:具备对1位信息存储的能力
How?用一个灯泡确定锁存器的数据输出信号
  • 8-1选择器
How?用3个选择输入端输入8个数据
  • 3-8译码器

  • 读/写存储器(read/write memory)或随机访问存储器(Random Access Memory,RAM)

    • 地址端口(Address)
    • 3-8译码器(输入端)
    • 8位锁存器
    • 8-1选择器(输出端)
AD:RAM相比顺序型存储器
  • 读写自由
EXP:8x1RAM阵列的扩充
  • 增加1个数据输入:8x2RAM阵列

  • 增加1个地址端口:16x1RAM阵列
    R A M 阵 列 的 存 储 容 量 = 2 地 址 端 口 的 数 量 RAM阵列的存储容量=2^{地址端口的数量} RAM=2

  • 10个地址端口,8个Data In和Data Out:1024x8RAM阵列

  • 控制面板

What?字节的单位换算

1 安 字 节 = 2 10 批 字 节 = 2 20 太 字 节 ( T ) = 2 30 吉 字 节 ( G ) = 2 40 兆 字 节 ( M ) = 2 50 千 字 节 ( K ) = 2 60 字 节 1安字节=2^{10}批字节=2^{20}太字节(T)=2^{30}吉字节(G)=2^{40}兆字节(M)=2^{50}千字节(K)=2^{60}字节 1=210=220(T)=230(G)=240(M)=250(K)=260
1 安 字 节 ≈ 1 0 3 批 字 节 ≈ 1 0 6 太 字 节 ( T ) ≈ 1 0 9 吉 字 节 ( G ) ≈ 1 0 12 兆 字 节 ( M ) ≈ 1 0 15 千 字 节 ( K ) ≈ 1 0 18 字 节 1安字节\approx10^{3}批字节\approx10^{6}太字节(T)\approx10^{9}吉字节(G)\approx10^{12}兆字节(M)\approx10^{15}千字节(K)\approx10^{18}字节 1103106(T)109(G)1012(M)1015(K)1018

  • 讨论存储器时,通常使用字节数;
  • 描述在线路中流动的数据时,使用比特(千比特每秒kbps与兆比特每秒mbps)
PRO:当前存储器存在的隐患
Created with Raphaël 2.2.0 断掉继电器的电源 继电器还原未触发状态 RAM存储的数据彻底消失 RAM被称为“易失性存储器”
  • 易失性存储器需要恒定的电流。

17. 自动操作

怎样让加法器自动地完成数据输入和计算?
编写程序。

  • 累加器
改进
锁存器上的灯泡显示结果
RAM阵列的控制面板检查结果
EXP:自动加法器除了可以累加一组数字,还可以自主确定累加多少数字,并记住RAM中计算结果的个数
  • 指令码或操作码(operation code,opcode),即机器码(machine codes)
    • Load(加载)
    • Store(保存)
    • Add(加法)
    • Subtract(减法)
    • Add with Carry(进位加法)
    • Subtract with Borrow(借位减法)
    • Halt(停止)
    • Jump(跳转)
    • Conditional Jump(条件跳转)
      • Jump If Zero(零转移)
      • Jump If Carry(进位转移)
      • Jump If Not Zero(非零转移)
      • Jump If Not Carry(无进位转移)
    • Call(记录了“从何处跳转”)
    • Return(返回到跳转点)
  • 数据与代码分别写入RAM
    • “数据”存储器
    • “代码”存储器
PRO:代码与数据存储器同步、顺序
  • 保存这些数的存储单元的地址不连续
  • 不允许使用前面的计算结果
Solution:根本性的修改
  • 每一个指令在存储器中仅占据3个字节的空间(除了Halt),其中1个字节为代码本身,另外两个字节用来存放1个16位地址
  • 设计关键:把代码RAM阵列的数据输出到3个8位锁存器
    • 指令代码
    • 地址高字节
    • 地址低字节
  • 牺牲了运算速度(TANSTAFL工程准则)
  • 放弃两个独立的RAM阵列:操作码和操作数存放在同一个RAM阵列
DIF:计算机(computer)与计算器(calculator)
  • 能否控制重复操作或循环(looping)
数字计算机 digital computer
处理器 processor
存储器 memory
输入 input
输出 output
中央处理单元 central processing unit,CPU
64KB RAM阵列
开关
灯泡
What?处理器的若干组件
  • 累加器:简单锁存器,保存内部数据
  • 算术逻辑单元(ALU):算术运算与逻辑运算
  • 程序计数器(Program Counter,PC)
What?硬件与软件
  • 硬件(hardware)
    • 继电器
    • 电线
    • 开关
    • 灯泡
  • 软件(software)
    • 输入到存储器中的指令
    • 输入到存储器中的数值
      “ 软 件 ” = “ 计 算 机 程 序 ( c o m p u t e r p r o g r a m ) ” “软件”=“计算机程序(computer program)” =(computerprogram)
Who?程序设计人员=编码员(coders)=软件工程师(software engineers)
What?汇编语言(assembly language)
  • 全数字的机器语言和指令的文字描述的一种结合体
  • 标号表示存储器地址
  • 手工汇编,纸上操作
  • 错误(bug)

机器所需要的仅仅是能够做加减法的硬件以及利用条件跳转指令执行代码的方法

本书中不讲有关**算法(algorithm)**的内容。

继电器
真空管
晶体管

18. 从算盘到芯片

计算工具的发展史

How?计算工具的发展史
对乘法的研究
初步具备自动功能
算盘
约翰.纳皮尔发明对数
对数表
带对数刻度的滑尺
乘法辅助器-纳皮尔骨架
威廉.帕斯卡制造出最早的机械计算器
杰奎德织布机,打孔的金属卡片
查尔斯.巴贝芝设想出差分机与解析机
霍尔瑞斯卡片-IBM卡片
How?比较微处理器性能的三个衡量标准
  • 数据通路宽度
  • 最大时钟频率
  • 寻址能力
    以上三个数字指标并不影响一台计算机的计算能力,关键点在于处理器的速度

19. 两种典型的微处理器

将中央处理器的所有构件封装到一块硅芯片上,即微处理器。
两种典型微处理器:Intel 8080和Motorola 6800

What?计算机的指令集(Intel 8080)
助记符指令含义
LOD加载
STO保存
STA保存到累加器
LDA加载到累加器
STAX保存到BC或DE寄存器
LDAX加载到BC或DE寄存器
MOV把一个寄存器中的内容转移到另一个寄存器(可以是原来的寄存器、累加器)
MVI传送立即数
HLT停止
ADD加法(累加器)
ADC进位加法(累加器)
SUB减法(累加器)
SBB借位减法(累加器)
AND
OR
XOR异或
CMP比较,可设置标志位
ADI立即数加法
ACI立即数进位加法
SUI立即数减法
SBI立即数借位减法
ANI立即数与
XRI立即数异或
ORI立即数或
CPI立即数比较
STC令CF置1
CMC令CF取反
CMA累加器中的数按位取反
DAA十进制调整累加器,使用BCD码进行十进制的算术运算
INR寄存器或存储器中的数加1
DCR寄存器或存储器中的数减1
RLC使累加器循环左移
RRC使累加器循环右移
RAL带进位的累加器循环左移
RAR带进位的累加器循环右移
PUSH压入堆栈
POP弹出堆栈
LXI对寄存器对和堆栈指针加载扩展的立即数(两个字节)
INX对寄存器对和堆栈指针加1
DCX对寄存器对和堆栈指针减1
DAD把由任意2个寄存器组成的16位寄存器对的内容加到寄存器对HL中
SHLD直接保存HL中的数据
LHLD直接加载数据到HL
PCHL将HL保存的数据加载到程序计数器
SPHL将HL保存的数据加载到堆栈指针
XTHL把HL中的内容和堆栈顶部2个字节进行交换
XCHG把DE中的内容和HL中的内容进行交换
JMP转移
JZ零转移
JNZ非零转移
JC进位转移
JNC无进位转移
CALL调用
RET返回跳转点
OUT把累加器中的内容写入到紧跟该指令后的字节所寻址的端口
IN把一个字节从端口读入到累加器
DI禁止中断
EI允许中断
RST重新启动,立即跳转到特定的地址
NOP无操作
What?标志位(flag)
  • CF-进位标志位
  • ZF-零标志位
  • SF-符号标志位
  • PF-奇偶标志位
  • AF-辅助进位标志位

实现人机交互:输入/输出设备(I/O)

CMP:Motorola 6800相比于Intel 8080
  1. 时钟信号较简单
  2. 没有独立I/O端口
  3. B也是累加器,无其他8位寄存器
  4. 16位索引寄存器(类似HL寄存器)
  5. 对应操作码和助记符完全不同
  6. 无奇偶标志位,有溢出标志位
  7. 汇编语言不兼容
  8. 6800高前低后,8080低前高后
Why?根据摩尔定律增加的大量晶体管
  1. 增加数据宽度
  2. 应对新的指令(浮点数、重复计算、图片与电影)
  3. 使用多种现代技术提高运行速度

20. ASCII码和字符转换

如何用比特来存储文本呢?
ASCII码。

  • 字符编码集
  • 文本字符串(string)
  • 1874年波多电传码(默里编码)应用于电传打字机
    • DAD:
      1. 转义码易导致出错
      2. 不能唯一表示
      3. 不能区分大小写
  • 回车与换行
  • 美国信息交换标准码-ASCII码
  • Unicode(统一化字符编码标准)
    • PRO:
      改变了字符与存储空间之间“单字符单字节”的等价对应关系(在存储空间上付出代价)

21. 总线

总线(bus)就是数字信号的集合,而这些新好呗提供给计算机上的每块电路板。

Created with Raphaël 2.2.0 计算机中各部件按照功能被分别安装在两个或更多的电路板上 电路板之间通过总线(bus)通信
  • 四类信号:
    • 地址信号
    • 数据输出信号
    • 数据输入信号
    • 控制信号
  • 开放体系结构(Open Architecture)原则
  • IBM PC
  • 三态输出
  • 电子射线管(CRT)-视频显示器/监视器
  • 字符生成器,只读存储器(read-only memory,ROM)
    颜 色 数 量 = 2 每 个 像 素 赋 予 的 比 特 数 颜色数量=2{每个像素赋予的比特数} =2
  • 磁介质存储器逐渐发展成目前最为流行的长期存储器。
    • 录音电话
    • 卷轴式磁带(顺序访问)
    • 磁盘(快速访问)
      • 软盘
      • 硬盘
DIF:随机访问存储器与磁介质存储器
  • memory与storage
  • 主要区别:存储的信息是否易失
  • 显著区别:微处理器发出地址信号通常寻址随机访问存储器
  • 形象比喻:办公桌的桌面与文件柜

22. 操作系统

M i c r o p r o c e s s o r + R A M + K e y b o a r d + V D + D i s k D r i v e r Microprocessor+RAM+Keyboard+VD+Disk Driver Microprocessor+RAM+Keyboard+VD+DiskDriver
MISSING:软件

键盘处理程序及命令处理程序简化了工作,淘汰了控制面板。同时命令处理程序使得计算机变得可交互(interactive)。

  • 只读存储器(ROM、PROM、EPROM)

文件系统(file system)可以记录存储位置。

What?内存空间
0000h系统参数
0100h临时程序区域(TPA)
控制台命令处理程序(CCP)
基本磁盘操作系统(BDOS)
最高地址基本输入/输出系统(BIOS)
  • CP/M OS三组分:
    • CCP
    • BDOS
    • BIOS
What?控制台可识别命令
命令内容
DIR显示磁盘的目录信息
ERA删除磁盘中的文件
REN改变文件名
TYPE显示文本文件的内容
SAVE保存文件
  • 不能被CP/M识别的命令被默认为是保存在磁盘上的一个程序名

OS提供应用程序接口(API),让程序能够方便地访问计算机的硬件。API是一个与设备无关(device-independent)的接口,它屏蔽了硬件之间的差异。

  • 1981 IBM PC —— MS-DOS
    • 文件系统采用FAT形式
  • 20世纪70年代初 UNIX系统
    • 可移植性(portable)
    • UNIX思想
    • 时分复用技术
    • Linux系统

23. 定点数和浮点数

2.75用二进制怎样表示呢?

  • BCD码
What?定点数与浮点数
  • 定点格式数
    • 钱款、账户
  • 浮点格式数
    • 极大数或极小数
    • 科学计数法
      • 符号位s
      • 指数位e
      • 有效数位f
        ( − 1 ) s ∗ 1. f ∗ 2 e − 127 (-1)^s*1.f*2^{e-127} (1)s1.f2e127
    • 单精度(float)与双精度(double)

浮点数运算可以处理一些较为繁杂的函数运算,如平方根、指数、对数和三角函数。


24. 高级语言与低级语言

使用机器码(低级语言)编写程序如同用牙签吃东西,费力又费时;人们想出了一种效率更高的编程方法——高级语言。

  • 低级语言:汇编语言

    • 与硬件关系紧密
    • 比机器语言要简单,但微处理器不能解释汇编语言
    • 希望最好由计算机独自完成语言转换的工作——汇编器(assembler)
    • DAD:
      • 非常乏味,微处理器芯片级的编程,微小的细节
      • 不可“移植”
  • 高级语言

    • 需要编写一个编译器(复杂
    • AD:
      • 易用性
      • 可移植性
    • DAD:
      • 没有让处理器变强大
      • 不能使用某些处理器的特有功能
  • 第一个编译器——A-0

  • 最古老的高级语言——FORTRAN

  • ALGOL
    程 序 设 计 : 科 学 o r 艺 术 ? 程序设计:科学or艺术? or

  • 第一个商务系统所使用的程序设计语言——COBOL

    • 支持读取记录(record)和生成报表(report)
  • IBM PL/I

    • 融合性
      • ALGOL的块结构
      • FORTRAN的数学函数功能
      • COBOL处理记录和报表的能力
    • 使用不广泛
  • BASIC

  • Pascal

    • 继承性
      • ALGOL的大部分结构
      • COBOL的记录处理功能
  • Ada

  • C

    • 支持移位操作与按位布尔运算操作
    • 指针(pointer)
    • “高级汇编语言”

所有的类ALGOL语言设计模式都是基于冯·诺依曼计算机体系的。此类语言进行改进后产生了主要应用在图形化操作系统中的面向对象程序设计语言。


25. 图形化革命

要充分利用计算机日益增长的运算和处理能力,就必须不断改进计算机系统中的用户接口(User Interface),它是人机交互的轴心。图形化革命

  • 《思维之际》与麦克斯存储器(Memex)

  • 用户界面(User Interface)

  • 从字符显示到图形显示

  • 软件之所以被设计出来,其最终目的是——《为了扩展人类的智慧》。

  • Alto——图形用户界面(GUI)

  • 麦金托什机(Macintosh)——Mac OS

  • Windows

  • 面向对象程序设计思想(OOP)

    • 对象(object)实际上是代码和数据的组合
    • 应用于图形操作系统
    • C++
  • 集成开发环境(IDE)

  • 可视化教程(Visual Programming)

What?计算机图形的两个分支
  • 矢量(图元文件)
  • 光栅(位图)

位图和图元文件都是数字化的可视信息。

What?数据压缩(Data Compression)
  • 无损压缩技术
    • 游程长度编码(RLE)
    • 图形交换格式(GIF)-LZW
  • 有损压缩技术
    • 联合图像专家组(JPEG)-也包含无损压缩技术
位图文件 图元文件 困难 光学字符识别(OCR ) 容易 位图文件 图元文件

音频信息也能转换成比特和字节。

  • 脉冲编码调制技术(PCM)-CD
  • 振动是声音之源
  • 声波可以被模拟
  • 模拟数字转换器(ADC)与数字模拟转换器(DAC)
    • 模拟电压与二进制数的转换
AD:数字化声音相比于模拟声音
  • 可以实现无失真的转录或复制

CD可以存储声音,也可以存储数据。(CD-ROM)

  • 多媒体(multimedia)
    • 声音
    • 音乐
    • 视频
How?实现计算机与人对话
  • 预先录制,文件形式存储
  • 把ASCII码转换成波形数据

把波形数据转换成ASCII码称为语音识别,是一个极其复杂的过程。从本质上来讲这是一个利用编程技术使得计算机“理解”人类语言的过程,这正是人工智能(Artificial Intelligence)所研究的领域。

  • 数字化电影
    • 压缩技术:移动图像专家小组(MPEG)
    • HDTV与DVD
    • DVD将替代CD-ROM成为新的软件存储媒介

与万·布什提出的概念不同,所有信息并不一定要触手可及,真正使它们达到信息共享的做法是计算机互联,这样做还可以更有效地利用存储空间。

  • 调制与解调
  • Internet 非中心化的系统
    • 协议的集合
    • TCP/IP协议
    • 万维网(World Wide Web)
    • HTML格式 不是编程语言
    • 超文本(hypertext)-相关链接信息
    • 服务器端(Server)与客户端(Client)
Why?Web站点不为计算机提供一个可执行程序
  • 兼容性

  • 安全性

  • Java

    • 介于编译语言与解释语言之间,编译的结果不是机器码,而是Java字节码
    • Java字节码可以在Java虚拟机上被解释
    • 平台无关性:Java程序的运行不受限于机器与图形操作系统
电线
光纤
电信号
光信号

光 子 的 速 度 无 与 伦 比 光子的速度无与伦比


2019/9/24 9:24完成编辑


Additions

计算机技术发展史上的杰出人物简列

  • 塞缪尔·莫尔斯:发明了莫尔斯码,促进了第一条电报线路架设完成(现代通信开始的标志
  • 查尔斯·巴贝奇计算机事业的伟大先驱,分别提出了差分机与解析机的设想
  • 路易斯·布莱叶:发明了布莱叶盲文(“点字”)
  • 奥古斯都·德·摩根:发表《形式逻辑》,提出德·摩根定律
  • 乔治·布尔:发表《思维规律》,提出布尔代数(数学描述逻辑的方法出现
  • 赫尔曼·霍尔瑞斯:发明了霍尔瑞斯穿孔卡片(在1890年美国人口普查中取得成功),创立了制表机公司(IBM公司的前身
  • 康拉德·楚泽:建造完成第一台继电器计算机
  • 艾伦·M·图灵计算机科学之父、人工智能之父,提出著名的图灵机模型与图灵测试法,曾在二战期间协助军方破译德国的"Enigma"代码生成器
  • 约翰·安布罗斯·弗莱明、德·福雷斯特:发明了真空管(成为取代继电器的关键部件)
  • 霍华德·艾肯:在IBM公司的资助下,研制成功世界上第一台自动连续可控计算机(ASCC)Harvard Mark I
  • J·普利斯普·埃克特约翰·莫克利:设计出使用了18,000个真空管,大约30吨重的电子数字积分计算机(ENIAC),开发了第一台商用计算机——通用自动计算机(UNIVAC)
  • 万·布什“信息时代的教父”,信息论之父香农的老师,发表论文**《思维之际(As We May Think》**,其中提出了微缩摄影技术和麦克斯储存器(Memex)的概念
  • 约翰·冯·诺依曼计算机之父,提出了计算机的“冯·诺依曼结构”
  • 克劳德·香农信息论之父,发表《通信过程中的代数理论》,开创了信息论研究领域
  • 约翰·巴丁、沃尔特·布兰坦:发明了晶体管(取代真空管,开创了固态电子器件时代)
  • 威廉·肖克利:晶体管的发明者之一,在加利福尼亚帕罗奥图市成立肖克利半导体实验室,硅谷走向电子产业新时代的引导者
  • 戈登·E·摩尔:Intel公司的创始人之一,提出著名的摩尔定律
  • 肯·汤普森:UNIX操作系统之父
  • 丹尼斯·M·里奇C语言之父、UNIX之父
  • 比尔·盖茨微软公司创始人
  • 斯蒂夫·乔布斯:美国苹果公司联合创始人

计算机技术发展史上的著名组织与公司简列

  • 3
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值