IA-32指令码(Intel、AMD的CPU使用的指令码)由二进制码组成,格式如下图所示。
其中,指令前缀(Instruction Prefixes)可包含1到4个修改操作码行为的1字节前缀,它们分别是锁定前缀和重复前缀、段覆盖前缀和分支提示前缀、操作数长度覆盖前缀、地址长度覆盖前缀等。操作码(Opcode)定义了处理器执行的功能;修饰符包括ModR/M(寻址方式说明符)、SIB(比例–索引–基址)、Displacement(移位),定义执行的功能中涉及存取的具体寄存器和内存位置;数据元素(Immediate)是完成功能所需要使用的数据,这些数据既可以是直接的数据值,也可以是数据在内存中的地址。
资料来源:《C指针原理揭秘:基于底层实现机制》,文章链接:https://developer.aliyun.com/article/726057
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。