汇编程序员眼中的系统结构

汇编程序员眼中的计算机结构:微处理器CPU中包含指令寄存器PC(Program Count),它指向的是下一条指令的地址,在处理器中是EIP或RIP。寄存器与寄存器堆:在处理器内部的以名字来访问的快速存储单元。条件码:用于存储最近执行指令的结果状态或者用于条件指令的判断执行。存储器:以字节编码的连续存储空间。

Control Flow(控制流):就是上边说的条件码,可以被认为是单个位的寄存器

注:状态寄存器又名条件码寄存器,它是计算机系统的核心部件——运算器的一部分,状态寄存器用来存放两类信息:一类是体现当前指令执行结果的各种状态信息(条件码),如有无进位(CF位)、有无溢出(OV位)、结果正负(SF位)、结果是否为零(ZF位)、奇偶标志位(P位)等;另一类是存放控制信息(PSW:程序状态字寄存器),如允许中断(IF位)、跟踪标志(TF位)等。有些机器中将PSW称为标志寄存器FR(Flag Register)。


栈:一块内存区域。%esp存储栈顶指针。从高地址向低地址增加,即:栈大小是向栈顶增长的,而地址是向栈底增长的。

压栈操作


出栈操作

X86通用寄存器,此处只有%rsp功能固定(特殊寄存器):指向栈顶地址,其他寄存器都实现通用,但此处,%rbp一般还用于存放栈底地址。

  • 一般通用寄存器可以任意使用,但仍有一些特殊规定,一般下列几个寄存器是固定存放:
  • ax(accumulator): 可用于存放函数返回值
  • bp(base pointer): 用于存放执行中的函数对应的栈帧的栈底地址
  • sp(stack poinger): 用于存放执行中的函数对应的栈帧的栈顶地址
  • ip(instruction pointer): 指向当前执行指令的下一条指令



  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值