汇编学习笔记

三种语言区别:

机器语言:机器语言(Machine Language)是直接被计算机的中央处理器(CPU)识别和执行的一种低级语言。它是计算机能够直接理解并执行的指令集合,由二进制代码(0和1)组成。由于计算机是需要电的,而电路设计只有两种状态:1(真·通电)0(假·未通电),所以计算机中存储的任何文件、接收的任何指令都是由0和1组成的,即计算机只能读懂二进制

汇编语言:汇编语言(Assembly Language)是一种低级语言,它介于机器语言和高级语言之间。汇编语言代码比机器语言更易于人类阅读和编写,但仍然保持了与机器语言相近的执行效率和硬件控制能力。

高级语言:高级语言(High-level programming language)是一种独立于机器,面向过程或对象的编程语言。它是参照数学语言而设计的,其表达方式近似于日常会话,使得程序编写更加容易理解。

进制:

进制的定义:N进制,由N个符号组成,逢N进1。例如十进制逢十进一。符号是由人规定的,不一定是1,2,3,4,5,6,7,8,9。

进制间的运算:进行运算时不必转化为十进制后运算,借助加法表和乘法表可以直接进行进制的运算。

数据宽度:

byte(字节): 8 位。

word (字):16位,两字节。

dword(double word的缩写,双字):32位,4字节。

为什么符号数为0的是正数,为1的是负数?

因为假设储存八位数据,那么0000 0000~0111 1111是正数,1000 0000~1111 1111是负数。

原码补码反码:

原码:最高位为符号位,其余各位为数值本身的绝对值

反码正数反码与原码相同,负数符号位为1,其余位对原码取反

补码正数补码与原码相同,负数符号位为1,其余位对其反码加1

例如:原码:1000 0001,反码为:1111 1110,补码为:1111 1111

计算机加减乘除:

计算机只会进行(and,&)、或(or,|)、异或(xor,^)、非(not,~)、左移(<<)、右移(>>)这几种运算,加减乘除是通过这几种运算实现的。

加法的实现:

其他运算可用加法演变出来。

寄存器:

寄存器是一种特殊的存储单元,它位于CPU内部,具有非常高的存取速度。寄存器用于暂时存储CPU执行指令时所需要的数据、指令地址和状态信息。由于寄存器位于CPU内部,与CPU的物理距离较近,因此其访问速度远高于内存,但是寄存器的容量相对较小。

  • 通用寄存器:通用寄存器是计算机中央处理器(CPU)中的一个重要组件,它们是一种高速的内部存储器,用于存储和操作计算机中的数据。
  • 控制寄存器:计算机中用于控制和确定处理器操作模式以及当前执行任务特性的重要组件。常见控制寄存器包括CR0、CR1、CR2、CR3等。
  • 段寄存器:段寄存器是因为对内存的分段管理而设置的,它们的主要作用是存储与内存分段相关的信息,以便处理器能够正确地访问和管理内存。

通用寄存器:

32位的通用寄存器(8个):EAX、ECX、EDX、EBX、ESP、EBP、ESI、EDI

16位的通用寄存器 : AX,BX,CX,DX

8位的通用寄存器 :AH,AL,BH,BL,CH,CL,DH,DL

  • 数据寄存器:如AX、BX、CX、DX等,它们可以分别拆开为两个8位寄存器(如AH和AL)。这些寄存器在数据处理和运算中起着重要作用。
  • 变址寄存器:如SI、DI等,它们主要用于存放存储单元在段内的偏移量,以实现多种存储器操作数的寻址方式。
  • 指针寄存器:如BP、SP、EBP、ESP等,它们主要用于存放堆栈内存储单元的偏移量,为以不同的地址形式访问存储单元提供方便。

内存:

内存和寄存器都是存储数据的,但由于CPU中的寄存器有限(造价比较昂贵),所以我们可以给每一个寄存器取名,但内存不一样,内存太大了无法取名字,所以我们只能使用编号。当我们想向内存中读取数据时,就需要使用到这个编号,这个编号我们称之为内存地址(32位),每一个内存地址(编号)都能存储一个字节(8位)。内存地址是32位的(32位表示32个0和 1,但我们一般使用16进制去表示,例如:0x00000000),程序独立存储的内存空间范围为:0 - 0xFFFFFFFF,能存储的位数就是(0xFFFFFFFF+1)*8,加一是因为0也算一位,乘八是因为每块内存可以存储一个字节(8位),转为十进制就是:34359738368 / 8 / 1024 / 1024 / 1024 = 4G(换算:1Byte = 8Bit, 1KB = 1024Byte, 1MB = 1024KB, 1GB = 1024MB),即cpu可以控制4G的内存

段:

“段”(Segment)是一个与内存管理和组织相关的概念,它指的是内存中被划分出来的一个连续区域,用于存储特定类型的数据或代码。段的划分和管理是操作系统和计算机硬件共同协作的结果,旨在提高内存的使用效率和安全性。

1.基础:物理地址 = 段地址 * 16 + 偏移地址

               物理地址 = 段地址 << 4 + 偏移地址

例如假设段地址是0x1230,偏移地址是0x00c8,那么物理地址是0x12300+0x00c8=0x123c8。

2.做法: 编程时,可以根据需要将一组内存单元定义为一个段,用一个段地址指示段,然后用偏移地址访问段的内存单元。

3.三种段:

  • 数据段。将段地址放在DS中,用mov,add,sub访问内存单元的指令时,cpu将我们定义的数据段的内容当数据段来访问。
  • 代码段。将段地址放在CS中,将段中的第一条指令的偏移地址放在IP中,cpu将逐条执行我们定义的代码段的指令。
  • 栈段。将段地址放在SS中,将栈顶单元的偏移地址放在SP中,cpu在进行栈操作(push,pop)时,将我们定义的栈段当栈空间使用。

堆栈:

  1. 后进先出(LIFO):堆栈按照后进先出的原则存储数据,即最后插入的元素将最先被删除。
  2. 一端操作:堆栈的所有插入和删除操作都只能在栈顶进行,栈底固定,栈顶浮动。
  3. 记忆作用:在堆栈的插入与删除操作中,不需要改变栈底指针。

push ax操作执行的步骤:

  1. sp = sp - 2
  2. 将ax的内容送入SS:SP指向的内存单元处,SS:SP此时指向新栈顶

POP ax操作执行的步骤: 

  1. SS:SP指向的内存单元处的数据送入ax中
  2. SP = SP + 2,SS:SP指向当前栈顶下面的单元,以当前栈顶下面的单元为新栈顶。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值