/*碎碎念
先是纯个人想法吧,大一也学过c,c++,然后到了java,不知道为什么其实是不喜欢面向对象的,不清楚为什么吧,就感觉做什么都很懵,代码写的很随意,然后学下来也不知道学了什么,感觉就是在一个编译器上面写写写,老师说课设可以自己写一个编译器的时候就惊呆了,哇塞编译器不是规定的嘛,没有编译器怎么写代码,现在想想其实挺可笑……因为没有开设过关于计算机硬件方面的学科,加之自己也不是一个勤快好学的人,想过去了解但是总是没有做过,这时候汇编这门课程开设了,很多学长学姐都说汇编超级难,抱着战战兢兢的心态上了课发现这门课程意外的很合我的胃口,比起作为一门编程语言,感觉更适合作为大一时的基础课程上,它更加贴近计算机本身,规则感强了很多,能够帮助我们了解计算机执行指令的过程,实现代码的过程也更为清晰。汇编给我的感觉很严谨,很规范,由此也增加了它的复杂性,有很多零零碎碎的点,我算个零基础的小白吧,也不知道怎么写技术性的博客,就权当用来记录学习汇编过程中一些易忘的小笔记吧。*/
笔记:
磁盘->内存->cp
1B=8bit 1kB=1024B 1MB=1024KB 1GB=1024MB 1TB=1024GB
在内存或磁盘上,指令和数据没有任何区别,都是二进制信息。
8086有16根数据线和20根地址线,它既能处理16位数据,也能处理8位数据。可寻址的内存空间为1MB。
cpu是由运算器、控制器和寄存器组成的,这些器件靠内部总线(总线分为内部总线和外部总线,外部总线是连接cpu和主板上的器件,主要分为数据总线(宽度决定CPU和外界的数据传送速度,n根数据总线一次可以传送一个n位的二进制数据),控制总线(宽度决定CPU对外部的控制能力)和地址总线(‘有N根地址线’则地址总线宽度为N,最多可以寻找2的N次方个内存单元))相连接。
通用寄存器:AX、BX、CX、DX,可分为两个可独立使用的8位寄存器来用(Eg:ax分成al和ah,运算结果溢出时候,溢出的数字不会存放在ah中。)
汇编指令不区分大小写。
两条指令:mov ax,bx add ax,bx
地址加法器:物理地址=段地址*16+偏移地址
CS IP
8086中,任意时刻,CPU将CS:IP的指向内容当作指令执行;
修改:jmp 段地址:偏移地址;仅修改IP:jmp 某一合法寄存器
debug命令:
r<回车>显示寄存器的值 r ax<回车>查看ax的值可修改
d 地址范围 显示指定范围内存储单元的内容 d 地址 从指定地址开始显示128 字节 d从当前开始显示128个字节
e 地址从指定偏移地址开始修改(连续修改)存储单元内容 e地址 数据(空格隔开) 从指定地址开始用给定数据修改存储单元
a 从指定地址开始输入符号指令
g=地址1 地址2 运行地址1到地址2 之间的程序 g=偏移地址 从指定地址开始执行,直到结束或者遇到INT g 偏移地址 从当前执行到指定偏移地址之前的指令 g 从cs:ip开始执行直到结束或遇到INT
t=偏移地址或p=偏移地址(遇到INT时必用) 从cs:ip开始单步执行
u 地址范围 将制定内存地址单元的内容反汇编成机器指令 u 地址 从指定地址开始反汇编连续32字节 u从当前偏移地址开始连续32字节
在汇编程序中,数据不能以字母开头,要在前面加上零;Eg:0A00h
数据段
段地址->ds
/*mov bx,1000H
mov ds,bx
mov al,[0] */
8086自动取ds中的数据为内存单元的段地址,不支持将数据直接送入段寄存器,于是用一个寄存器进行中转;【…】表示一个内存单元,里面的数字表示内存单元的偏移地址
栈段
段地址->ss,栈顶偏移->sp
任意时刻,ss:sp指向栈顶元素
设10000H-1000FH为栈段,ss->1000H,sp->0010H
push ax ;将ax中的数据入栈 ,sp=sp-2
pop ax ;从栈顶取出数据送入ax,sp=sp+2