汇编学习(X86 VC)

寄存器:

 

32       16      8
EAX 0    EAX     AH AL
ECX 1    ECX     CH CL
EDX 2    EDX     DH DL
EBX 3    EBX     BH BL
ESP 4    ESP
EBP 5    EBP
ESI 6    ESI
EDI 7    EDI
mov eax, dword ptr ds:[0x12ffc4]
或
mov eax, 0x12ffc4
mov ecx, dword ptr ds:[eax]
者是:以0x12ffc4为首地址的连续4个字节的内存单元中的值放到EAX中 

 

lex ecx, dword ptr ds:[eax]
把eax中存放的值, 放入ecx中(与mov有区别, 一个是值, 一个是值为首地址的内存单元中的值)
标志寄存器  (容器宽度)
进位标志位
CF:  只看最高位, 两者相加溢出CF=1(无符号)
奇偶标志位
P: 转为二进制后, 如果1的个数为偶, P位为1, 否则为0(只看最低有效字节)
辅助进位标志位
A: FFFF(16位只看倒数第二个F中的最高位)
   FF(8位看倒数第一个F中的最高位)
零位标志位
ZF:计算的结果为0, 则ZF=1
符号标志位
SF: 二进制的最高位为1,SF=1
溢出标志位
OF: 无符号只看C位, 即CF
     有符号看O, 即OF   1000 | 1100 = 0100      最高两位即 0 xor 1 = 1; OF=1
方向标志位
D: 当该位为0时, movs或stos为加;为1时, 反之;(esi, edi)


JMP 无条件修改EIP的值
CALL 等价 PUSH ESP
sub esp,0x4
mov dword ptr ds:[esp], eip+5(eip是还没进函数时的eip)

Ret 等价 pop eip
mov eip, dword ptr ds:[esp];
add esp, 4
 

单个函数堆栈图Debug版

                          release 版的是   esp在堆栈的移动来寻址内存,  基本变化不大

 

 

 

 

 

 

 

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值