标签:反汇编 c++ 计算机系统 编写 设备 cti 分享 组成 hit
ORIGINAL POST
此文总结第一、二、三单元所学。
因为前几节课没有去上,所以第一单元我可能不能非常正确地去总结,尽量按着老师的课件来看下去。
第一章都是计算机基础,或者可以说计算机组成原理的超级简略版?
silly binaries
计算机可以直接识别、执行。不是给人写的东西。
不同种类的计算机其机器语言是不相通的,按某种计算机的机器指令编制的程序不能在另一种计算机上执行。
silly string replacer
主体是汇编指令,使用助记符便于人记忆和使用。
机械语言是机械指令的集合,汇编语言是机械指令符号化。
每一种特定的汇编语言和其特定的机器语言指令集是一一对应的。(通用性还是较低)
有时间还是看看计算机组成原理吧。
-
还是叫成bus 直观。
如果说主板是一座城市,那么总线就像是城市里的公共汽车(bus),能按照固定行车路线,传输来回不停运作的比特。这些线路在同一时间内都仅能负责传输一个比特。因此,必须同时采用多条线路才能发送更多数据,而总线可同时传输的数据数就称为宽度,以比特为单位,总线宽度愈大,传输性能就愈佳。
PC上一般有五种总线*:
* Wikipedia 上说总线有五种,课本上只有前三种。
虚拟地址空间?
现代的内存管理单元是以页的方式,分割虚拟地址空间的。通过总线,CPU将各类存储器当做一个逻辑存储器对待。
感觉类似于把各个存储器mount 到地址空间上,使其拥有一个唯一的地址(路径)。
寄存器
快 少 在CPU里
字长:CPU在单位时间内能一次处理的二进制位数,反映出CPU内部运算处理的速度。
位宽:CPU通过外部数据总线与内存之间一次能够传送的数据位。
大概就是高速公路收费站和高速公路车道数的关系吧。
Four of them, AX, BX, CX, DX, can also be accessed as twice as many 8-bit registers.
4个:ax, bx, cx, dx
亦可使用ah, al 访问通用寄存器的高位和低位。
感觉main registers 翻译成通用寄存器怪怪的。
课本的编排是真的乱七八糟。
为什么第二章PPT第12页上说8086CPU的位宽是16位?
8086 数据总线16位, 地址总线 20位。
There are also three 16-bit segment registers (see figure) that allow the 8086 CPU to access one megabyte of memory in an unusual way. Rather than concatenating the segment register with the address register, as in most processors whose address space exceeds their register size, the 8086 shifts the 16-bit segment only four bits left before adding it to the 16-bit offset (16×segment + offset), therefore producing a 20-bit external (or effective or physical) address from the 32-bit segment:offset pair. As a result, each external address can be referred to by 212 = 4096 different segment:offset pairs.
也就是用
segment * 0x10 + offset = address
来实现IMB的寻址。
同时修改 cs ip
jmp segment:offset jmp segment:offset jmp segment:offset
只修改 ip
jmp register jmp register jmp register
不能用 mov ip, ax ,重要的事情说三遍
常用指令
没啥好说的,有问题就敲?
段真的还是挺不错的一个结局方法。
在我学习汇编之前,就已经了解到了一个不错的C/C++反汇编工具 —— Godbolt 。喜欢的可以试一试。
标签:反汇编 c++ 计算机系统 编写 设备 cti 分享 组成 hit
原文地址:https://www.cnblogs.com/sstst/p/9886994.html