今天要做什么?
为了更好的理解书中内容,需要学习下进制分析和汇编。
汇编语言其实应该叫叫机器指令符号化语言,目前的汇编语言是学习操作系统的基础。
一:触发器
电路触发器的锁存命令默认是断开的,是控制电路触发器是否锁存。

触发器有输入端和输出端,输入端就类似电路的开关,输出端就类似用小灯泡来控制显示。
二:
- 寄存器(锁存器)
寄存器是一个多输入,多输出的器件

当按下锁存的命令,所有的寄存器都在同一时刻命令。

问题:若某个寄存器是由八个触发器组成,它最大可以保存的数是多少?
1111 1111 =255
三:
带寄存器的加法机
5+7+25
这个预置开关是将左侧的输入锁存到寄存器R,一个个进入
先拨动开关 ,预置进去5,在拨动开关,然后拨动相加,在加法电路中进行相加操作,,然后寄存器R中的数字是12,再按照相同 步骤进入25
四:四则运算电路
根据预置加减乘除操作,寄存器中存放的内容,根据左侧电路生成的二进制数字和右侧寄存器中的存放内容,做出相应的变化(加减乘除)
(12+3)/(12+3) 如果做稍微复杂点的运算,但是寄存器只能保存一个值,就需要另外的去记
五
指令的概念,引入指令
增加一个寄存器,目前有两个寄存器,寄存器R和寄存器Z,左侧的电路输入,可以选择进入哪个寄存器, 两个寄存器中的值 也可以相互传送,如果这些命令都由开关控制,那开关就太多了,需要换一种思路。

指令:
根据接受的指令去执行相应的操作,可以囊括上面所有的开关。

六:
指令太多,最好有个容器保存起来,方便用,可以用内存

内存简单介绍

1:每个内存单元都有其编号,每个内存单元由八个二进制位组成
2:每个内存单元都有相应的编号,地址线输入相应的编号即可读取到相应的内存,地址线的数量决定了可以读到的最多的内存单元。
如果有八个二进制地址线,从0000 0000 到1111 1111,最多256个内存单元,2的n次方个内存单元。
3:内存单元的编号,就是他的内存地址
4习惯上,字节是用来描述二进制序列的长度单位。8个比特组成一个字节。字节的英语单纯是Byte,简称位B。1001 1101的长度是一个字节。
5:在主流的计算机上,内存单元的长度是8个比特,换句话说,每个内存单元的长度都是一个自己
6:内存的容量可以用内存单元的数量来统计。因为每个内存单元的长度是1个字节,所以经常用字节数来衡量。
根据内存的大小,内存的容量是以字节(B)、千字节(KB)、兆字节(MB)、吉字节(GB)和太字节(TB)来标称
1kb = 1024b
1MB =1024KB
1GB = 1024MB
1TB = 1024GB
7:练习,某内存有16条地址线,则他的容量有多大?每个内存单元的长度是多少?一个字节(8个比特)
0000 - FFFF 65536个字节 64KB
七:
内存数据线(入或者出)
内存要入或者出数据,需要通过数据线,是双向的
内存的操作入和出需要一个控制器,也就是读/写控制
如何写入:
1:先在地址线给一个地址
2:在数据线上给出一个要写入的数据
3:读写控制线发出写命令,就可以把数据写入给定的地址
如何读出:
1:现在先在地址线上给出一个地址,指出要读哪个单元
2:由读写控制线发出读命令,数据就会从指定的数据线上读出,并发送到数据线上
八:自动计算学习
运算器是在刚才四则运算的基础上增加了一i个指令指针寄存器
1:第一条指令是将207传送到寄存器R
2:将寄存器R中的内容和9相加,结果在寄存器R
3:将56传送到寄存器Z
4:将寄存器Z中的内容和48相减,结果在寄存器Z
5:将寄存器Z中的内容和48相减,结果在寄存器Z
6:将寄存器R和寄存器Z的内容相出,结果在寄存器R
7:将寄存器R的内容传送到地址位12的内存单元
8:可以进行停机
九:
处理器组成
总线接口部件、控制部件、指令执行部件
8086 是跨时代的16位处理器,因特尔一直保持兼容

每种处理器。例如64位处理器对应64位的寄存器和64位的算数逻辑部件。
指令集:任何一款处理器,所有包含的指令的集合称为指令集
算术运算指令和逻辑运算指令:逻辑运算
数据传送指令:内部寄存器之间,处理器和内存之间,处理器和外围设备之间
处理器状态控制指令:处理器的工作模式和工作状态
十:

Mov 指令 传送 赋值
add 加法指令 将,r和9中的数据相加在保存到r中
sub 减法指令,把寄存器z中的内容和48相减,在赋值给z。
div 除法指令,将寄存器r中的内容和z相除得到的商,再传给r
mov [12] ,r ,中括号中的地址是内存中的地址,把寄存器r中的内容,传送到寄存器[12]里面去。
Hlt 停机指令
十一:认识intel 8086处理器(低端字节序)内部的通用寄存器
AX/BX/CX/DX/SI/DI/BP/SP 16位寄存器 16个比特组成,从右往左寄存器编号是0-15

十进制 23235
16进制5AC3
换算方式

INTEL 8086通用寄存器划分
AX、BX、CX、DX 可以拆分成两个八进制的寄存器,分别是:
AX:AH AL
BX:BH BL
CX:CH CL
DX:DH DL

寄存器使用编号:

AX是16位的寄存器,一个字节八个比特,两个单词 一个字就是AX。
寄存器AH是寄存器AX的高字节部分,寄存器AL是寄存器AX的低字节部分

改变了寄存器AH的值,就改变了寄存器AX的值

DX(083C)(DH(08)、DL(3C))

十二:
8086的内存访问和字节序
十六进制的寄存器写入八位的内存,需要拆分成两个字节,假设写入0002编号的内存,那么0002编号的内存保存的就是16位寄存器的低字节部分,0003保存的是16位寄存器的高字节部分。(像这种寄存器低字节部分写入内存编号低地址单元,寄存器高字节部分写入内存编号高字节单元的称为 低端字节序)。

看的李忠老师网易云的汇编课程,笔记就先整理到这里,后续统一提交git仓库