汇编指令长度计算
- 汇编指令长度计算
- 1、无操作数指令
- 没有操作数的指令,指令长度为1字节。如
- es:
- ds:
- cbw
- xlat
- 没有操作数的指令,指令长度为1字节。如
- 2、操作数只涉及寄存器
- 操作数只涉及寄存器的指令,指令长度为2字节。如
- mov al,[si]
- mov ax,[bx+si]
- mov ds,ax
- 操作数只涉及寄存器的指令,指令长度为2字节。如
- 3、操作数涉及内存地址的指令
- 操作数涉及内存地址的指令,指令长度为3字节。如
- mov al,[bx+1]
- mov ax,[bx+si+3]
- lea di,[1234]
- mov [2345],ax
- 操作数涉及内存地址的指令,指令长度为3字节。如
- 4、操作数涉及立即数的指令
- 操作数涉及立即数的指令,指令长度为:寄存器类型+1。8位寄存器,寄存器类型=1;16位寄存器,寄存器类型=2。如
- mov al,8 ;指令长度为2
- mov ax,8 ;指令长度为3
- 操作数涉及立即数的指令,指令长度为:寄存器类型+1。8位寄存器,寄存器类型=1;16位寄存器,寄存器类型=2。如
- 5、跳转指令
- 跳转指令,分3种情况,指令长度分别为2、3、5字节。
- 段内跳转,指令长度=(目标地址-指令当前地址)+1
- jmp指令本身占用1个字节。
- (目标地址-指令当前地址)若能用1个字节表示,则占用1个字节,整体指令长度为2字节;如0113 jmp 0185 ;0185h-0113h=72h,72h可用1个字节表示
- 若需2个字节表示,则占用2个字节,整体指令为3个字节。如
- 0113 jmp 0845 ;0845h-0113h=732h,732h需用2个字节表示
- 2、段间跳转,指令长度为5字节。
- 如jmp 1234:5678
- 如jmp 1234:5678
- 段内跳转,指令长度=(目标地址-指令当前地址)+1
- 跳转指令,分3种情况,指令长度分别为2、3、5字节。
- 1、无操作数指令
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 25岁的心里话
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现