程序计数器

本页使用了标题或全文手工转换,现处于中国大陆简体模式
求闻百科,共笔求闻
PDP-1计算机(1959年)的控制面板,程序计数器就在面板的左上方。

程序计数器(英语:Program CounterPC)是一个中央处理器中的寄存器,用于指示计算机在其程序序列中的位置。在Intel x86Itanium微处理器中,它叫做指令指标(instruction pointerIP),有时又称为指令地址寄存器(instruction address registerIAR[1]、指令计数器[2]或只是指令序列器的一部分[3]

在大部分的处理器中,指令指标都是在提取程序指令后就被立即增加;也就是说跳跃指令的目的地址,是由跳跃指令的运算元加上跳跃指令之后下一个指令的地址(单位为比特或字节,视电脑形态而定)来获得目的地。

处理器通常从存储器中顺序获取指令,但控制传输指令通过在PC中添加一个新值来改变顺序。这些包括“分支”(有时称为“跳转”),“子例程调用”和“返回”。以某些断言结果为真为条件的传输可让计算机在不同条件下遵循不同的顺序。

“分支”规定下一条指令从内存中的其他地方获取。“子程序”不仅调用分支,而且还保存 PC 的先前内容。“返回”检索 PC 的保存内容并将其放回去,然后按照子程序调用的指令继续顺序执行。

参考文献

  1. Mead, Carver; Conway, Lynn. Introduction to VLSI Systems. Reading, USA: Addison-Wesley. 1980. ISBN 0201043580. 
  2. Principles of Operation, Type 701 and Associated Equipment (PDF). IBM. 1953 [2018-03-29]. 
  3. Harry Katzan (1971), Computer Organization and the System/370, Van Nostrand Reinhold Company, New York, USA, LCCCN 72-153191