1、操作系统位数与CPU位宽、线路位宽
先说结论:通常说的操作系统的位数,指的是线路位宽,也就是指地址总线的位数。
1.1 CPU位宽。
CPU位宽是指一次可以计算数据的bit数。有CPU在计算时,数据需要先保存在寄存器中,因此CPU位宽一般就是指寄存器的位数。如32CPU一次可以计算32bit的数据,64位CPU一次可以计算64bit的数据。
1.2 线路位宽
操作系统位宽一般就是指线路位宽。程序在执行时,需要通过地址总线去内存中找到对应数据或指令的地址。线路位宽就是指地址总线有多少根。
先看一下计算机是如何取出内存中的数据的:
首先,要明白内存是储存单元的集合,每个储存单元对应一个物理地址(如上图中的0x0000等),目前大多数计算机都是按照字节(Byte)编址的,8bit占用一个物理地址,也就是说一个物理地址对应1Byte的内存。
每根地址总线可以高电平(对应1)或低电平(对应0),相当于一根地址总线对应一个bit,因此,若是32根地址总线,那么就可以得到一个32bit的地址,地址的范围为0 ~ 2^32,由于每个地址对应1Byte的数据,因此内存的大小为 2^32 Byte,也就是4GB。
这就是为什么32位操作系统,一般内存最大就是4GB,因为内存大于4GB,操作系统也没法一次寻址,内存就显得有些浪费。
顺便再说一下,为什么不同的操作系统,C/C++ 指针变量的大小不一样?比如32位操作系统中,指针变量大小为4 Byte,64位系统为8 Byte。
这是因为指针的值的含义就是内存地址,在32位系统中,寻址的最大值为2^32,地址编码为0 ~ 2^32,刚好可以用一个32bit的数据来表示,也就是4 Byte。同样对于64位操作系统,寻址的最大值为2^64,需要用一个64 bit的数表示,也就是8 Byte。
1.3 线路位宽与内存的联系
程序在运行的时候,需要先加载到内存中,然后CPU根据地址总线去读取内存中的指令或数据。内存中的地址已byte进行编号,比如第一个byte编号为0x01,第二个地址编号为0x02 。。。如果是32为地址总线,那么可以得到一个32位的二进制数据,范围为 0 ~ 2^32, 因此32位操作操作系统(32位线宽)可以寻址的地址范围为4GB (每个地址都对应1Byte的内存)。所以说32位的操作系统最大寻址的内存是4GB。
总结:
通常说的操作系统的位数,指的是地址总线的位宽,32位操作系统地址总线根数就是32。而线路位宽是与内存紧密相关的,因为内存是通过地址总线来进行寻址的。
CPU位宽与线路位宽没有直接的联系。
2、位宽与计算机计算速度的关系。
2.1 CPU位宽直接影响计算机的计算速度。
这一点很好理解,因为CPU位宽越大,一次可以计算的bit数就越多。
2.1 线路位宽对运行速度的影响
总线其实可以分为地址总线、数据总线以及控制总线。
- 地址总线的位宽代表的内存可以寻址的范围,一般地址总线位宽越大,内存越大。虽然内存对计算没有直接影响,但是程序运行时需要加载在内存中,如果内存越大,加载的次数越少,显然越有利于程序的快速运行。
- 数据总线,可以将内存中的数据或执行送到CPU,显然线路越宽,传送数据或指令花费的时间越少,越有利于程序的快速运行。
- 因此就要要求,总线位宽、CPU位宽以及内存要相互匹配。
3、程序执行的基本过程。
3.1 冯诺依曼模型
要了解程序执行的基本过程,首先的知道计算机的基本模型-冯诺依曼模型。
直接上个图吧:
先说说计算过程中每个器件负责的功能:
- 内存:程序指令以及数据都是存储在内存中的,程序在运行过程中,需要通过地址总线(内存总线)来寻址,找到对应的内存地址。知道内存地址之后,即可以访问内存中的数据了或者想内存中写入数据。
- 内存总线:就是用来寻址,访问内存。
- 数据总线:知道内存地址之后,读取内存的数据或者写入数据时,数据是通过数据总线来传输的。
- 控制总线:用来发送和接收信号,比如复位和中断信号等。
- 控制单元:发出控制信号,并通过控制总线传输控制信号。比如让内存准备好数据,便于访问。
- 寄存器, 通用寄存器 – 保存计算过程中的数据, 指令寄存器 – 保存计算过程中的指令,程序计数器 – 相当于一个指针,指向下一条指令地址。
- 逻辑运算单元, 就是做加法或乘法等运算。
3.2 程序执行的详细过程
以计算a = 1 + 2为例。假如数据1储存在地址0x10, 数据2为0x14
这条语句编译之后被翻译为4条指令:
指令1:load指令,将地址0x10数据(即数据1)存入寄存器R0
指令2:load指令,将地址0x14数据(即数据2)存入寄存器R1
指令3:add指令,将寄存器R0与R1的数据相加,存入R2.
指令4:store指令,将R2处的数据写入a所在的地址。
参考文章:
https://www.cnblogs.com/xiaolincoding/p/13796525.html