汇编001_课上笔记

dosbox的使用

  1. 解压出来, 运行: movdosbox.exe

  2. 将主机的文件夹挂载到模拟器中, 为了能够让模拟器操作主机中的文件.

    1. mount C: d:\dosbox
    2. C: - 表示的是模拟器中的路径.
    3. d:\dosbox - 主机中的路径
    4. 将主机中的文件夹挂载到模拟器C盘
  3. 输入盘符,切换到挂载好的盘中.

  4. 启动debug

    1. 命令:

      1. 寄存器 : r - 查看/修改寄存器
        1. 修改寄存器 r ax
      2. 内存相关: d - 查看内存 , e-修改内存
        1. 查看内存: d 1000:200
        2. 修改内存: e 1000:200
      3. 运行相关: t - 单步步入 , p - 单步步过
      4. 反汇编相关:
        1. a - 进行汇编, a 1000:200 输入汇编代码
        2. u - 查看汇编 u 1000:200
      5. 退出调试器: q
    2. 使用TD.exe

16位汇编指令

指令帮助文档

  • imm - 立即数,操作数可以是数字. 后面带有数字,
    例如imm8-bit,imm16-bit,imm32-bit数字表示立即数的字节数.

  • reg - 表示通用寄存器种的任意一个, 后面带有数字,例如reg8,reg16; , 表示只能使用特定大小的寄存器, 例如, 如果是reg8就只能使用al,ah,bl,bh,cl,ch,dl,dh中的一个.如果是reg16,就不能使用al这种的8位寄存器.

  • seg/sreg - 表示段寄存器.只能是cs,ds,es,ss

  • mem - 表示内存, 后面带有数字,例如mem8,mem16,表示读写内存的字节数. 表示内存操作数大小时, 需要使用byte ptr,word ptr,dword ptr, 例如: byte ptr ds:[1000],表示能从ds:[1000]读写1个字节.

dword ptr ds:[1000],表示能从ds:[1000]读写4个字节.

汇编指令的使用规则

  1. 操作数只能是: 数字, 寄存器, 内存3种
  2. 两个操作数的大小必须一样.
    1. mov [1000h] , 100; 错误指令,无法确定内存操作数的大小,也无法确定立即数的大小. 改成mov word ptr [1000h],100
    2. mov ax , 10, 正确的, 如果已经确定了其中一个操作数的大小的时候, 另一个操作数的大小不用给出, :mov [1000h],ax ,此处虽然没有给出内存操作数的大小, 但是ax的大小是固定不变的, 因此, 内存操作数的大小就可以使用ax的大小来确定,就是word ptr.
  3. 两个操作数不能同时都是内存.
    1. mov [1000h],[1004h] 改成: mov ax,[1004h]; mov [1000h],ax
  4. 目标操作数不能是数字
    1. mov 1 , ax 错误

数据传输指令

  • mov - 将源操作数赋值到目标操作数
    –两个操作数的数据类型要相同
    –两个操作数不能同时为段寄存器
    –代码段寄存器cs不能为目的操作数,但可作为源操作数
    –立即数不能直接传给段寄存器
    –立即数不能作为目的操作数
    –指令指针ip,不能作为mov指令的操作数
    –两个操作数不能同时为存储单元
  • xchg - 交换两个操作数.
  • 栈操作有关的指令:
    • push - 将一个数值压入内存中(内存的地址由sp寄存器来提供)
    • pop - 将一个数值从内存提取出来,保存到目标操作数中内存地址由sp寄存器提供)
    • pushf/popf - 将标志寄存器的内容压入/弹出栈
    • pusha/popa - 将所有寄存器状态压入/弹出堆栈
      • 压入的顺序: ax,cx,dx,bx,sp,bp,si,di
      • 出栈的顺序, 和压入的顺序相反.

算术运算指令

    • inc -自增1(increment)
    • add - 加法 , 将源操作数累加到目标操作数上. 相当于+=
    • dec - 自减1(decrement)
    • sub - 减法, 将源操作数累减到目标操作数上, 相当于-=
    • 无符号乘法
      • mul 只有一个操作数, 使用al/ax作为默认操作数, 相乘得到的结果保存到ax/dx:ax中.dx:ax的意思是用两个寄存器代表32位的数,在这里表示32位的结果低16位存入ax中,高16位存入dx中。
        -mul有三种格式:
        –第一种,将8位的操作数与al相乘,
        –第二种是将16位的操作数与ax相乘
        –第三种将32位的操作数与eax进行相乘
        !注意:乘数与被乘数大小必须相同,乘数或被乘数不能是立即数,必须放在内存或寄存器中才能相乘。
    • 有符号乘法
      • imul 单操作数, 使用al/ax作为默认操作数, 相乘得到的结果保存到ax/dx:ax中.
      • imul 双操作数, 源操作数乘以目标操作数, 结果存放到目标操作数中.且第一个操作数必须是寄存器。
      • imul 三操作数, 后两个操作数相乘,结果存放到第一个操作数.
  • 除/取余
    • 无符号除法
      • div - 单操作数, 操作数是除数, 被除数是al/dx:ax, 8位运算时,商保存在al,余数保存在ah,16位运算, 商保存在ax,余数保存在dx
    • 有符号:
      • idiv 单操作数, 使用和div一样.

位操作指令

  • 移位运算:
    • shl - 左移运算
    • shr - 右移运算
    • and 按位与
    • or 按位或
    • not 按位取反

#段寄存器

课后作业

使用汇编语言将下列算式给翻译出来,只允许使用ax,bx,cx和sp寄存器,可以使用栈

int a=10;
int b=20;
int c=4;
a = (a << c) * (a>>c) / ((c ^ a) | (c ^b )) - (++c + --a)
部分示例:
mov ax,10;
mov bx,20;
mov cx,4;


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值