(汇编) 基于VS的x86汇编基础指令

环境

visual studio 选择x86运行

示例代码

/**
| 32位 | 16位 | 高8位 | 低8位 |
| ---- | ---- | ----- | ----- |
| EAX  | AX   | AH    | AL    |
 */
#include <iostream>

int main() {
    int32_t x = 1;
    int32_t y = 2;

    // 简单加法示例
    __asm {
        mov eax, x;
        mov ebx, y;
        add eax, ebx;
        mov x, eax;
    };

    ::std::printf("x = %d y = %d\n", x, y);
    
    return 0;
}

汇编基础

标志位

# visual studio 中的标志位
# OV UP EI PL ZR AC PE CY
  • OV 溢出
    • 超出表示范围为溢出 1,否则 0
  • UP 增量
    • 1:以递减顺序对数据串处理;0:以递增顺序对数据串处理
  • EI 允许中断
    • CPU允许中断1,否则0
  • PL 正
    • 运算结果为正则为1,否则0
  • ZR 零
    • 运算结果为0则为1,否则0
  • AC 辅助进位
    • 低4位向高位进位1,否则0
  • PE 奇偶校验
    • 最低16位中含1的个数为偶数为1,否则0
  • CY 进位
    • 最高位进位1,否则0

常用指令

此处介绍汇编的常用基础指令,不做过多展开,仅记录基本含义

指令作用e.g.
add加法add eax, ebx;
and按位与操作and eax, ebx;
call下一条指令地址入栈,跳到目标进行指令执行call 地址;
cmp操作数1-(符号扩展)操作数2
不保存,观察标志位
cmp eax, ebx;
dec自减dec eax;
div除法
结果,余数 (不同参数不同)
div bx;
imul乘法
(不同参数不同)
imul eax, ebx, ecx;
inc自增inc eax;
jmp跳转这是一系列指令
lea加载地址lea eax, 地址;
movmov eax, 114514;
movsd双精度赋值到寄存器
movss但精度数赋值到浮点寄存器
movsx/movsxd符号扩展传输
movs系列批量内存传输
movzx0扩 展传输
neg取反(±)neg eax;
not按位取反not eax;
or按照位或or eax, ebx;
pop及相关出栈pop eax;
push及相关入栈push eax;
rcl循环左移
最高位到cf,cf移入最低位
rcl eax, 次数;
rcr循环右移
cf填入最高位,最低位填入cf
rcr eax, 次数;
ret从栈中恢复地址ret ;
rol循环左移
最高位到cf和最低位,cf原值丢弃
rol eax, 次数;
ror循环右移
最低位填入最高和cf
ror eax, 次数
sar算数右移
符号位保留
sar eax, 数值;
shr逻辑右移
高位补0
shr eax, 次数
sub减法sub eax, ebx;
test按位与
不保存,观察标志位
cmp eax, ebx;
xor按位异或xor eax, ebx;

vs配置

寄存器

进入debug模式后,在顶部调试->窗口->寄存器

反汇编

在编辑界面,右击->转到反汇编

进入后右击选择显示具体信息

检测变量

注意设置不开优化




END

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值