汇编——数据传送指令 –Mov 传送数据到目的操作数mov eax,ebx mov edi,[ebx]–Movsx 先符号扩展,再传送对一个较小的整数如8位进行扩展使其变成一个较大的整数–Movzx 先零扩展,再传送一般用于将较小值拷贝到较大值中规则无论源最高位是 0/1扩展高位全部填0–Lea 将操作数的有效地址传送到指定寄存器LEA EDI, [ESI2] //EDI里面是地址–Xchg 交换两个寄存器或寄存器和内存单元的数据规则不能两个都是内存,不能立即数参与交换;寄存器↔寄存器/寄存器↔内存XCHG EAX, EBX //交换AX和BX寄存器的内容XCHG EAX, [ESI] //交换AX寄存器的内容和SI指向的内存单元的内容–Push Push onto the stack指令将数据压入堆栈Push eax //等价于Espesp-4 mov [esp],eax–Pop Pop from the stack指令从堆栈中弹出数据到指定寄存器Pop eax //等价于mov eax,[esp] espesp4–Pushad 压栈顺序从高地址往栈顶递减入栈入栈顺序EAX → ECX → EDX → EBX → ESP → EBP → ESI → EDIESP 压入的是压栈指令执行前原始值栈变化一次性 ESP - 328 个寄存器 ×4 字节 32Byte–Popad 出栈顺序和 PUSHAD 逆序从栈顶弹出出栈顺序EDI → ESI → EBP → ESP → EBX → EDX → ECX → EAX关键细节POPAD 弹出 ESP 时不会修改实际硬件 ESP 的值仅丢弃栈内 ESP 占位数据避免栈错乱常用于函数现场保存 / 恢复–BSWAP 交换32位寄存器里字节的顺序BSWAP EAX //原字节11 22 33 44 → 翻转后44 33 22 11 → EAX0x44332211–XADD 先交换再累加(结果在第一个操作数里)EAX5,EBX3XADD EAX,EBX // 执行后EAX538EBX5原EAX的值–LAHF 标志寄存器传送,将低8位标志寄存器 (SF/ZF/AF/PF/CF)送入AH寄存器–SAHF 标志寄存器传送,把AH的值写回 CPU 低 8 位标志位覆盖 SF/ZF/AF/PF/CF–PUSHF 16位标志入栈 ESP - 2–POPF 16位标志出栈 ESP 2–PUSHD 32位标志入栈 ESP - 4–POPD 32位标志出栈 ESP 4函数调用保存现场、异常处理时用来保存 CPU 标志位