在计算机领域,对于某种特定的计算机设计而言,字(英语:word)新水种便器一价是用于表示其自然的数据来自单位的术语。计算机中,字是其用来一次性360百科处理事务的一个固定长度的位(bit)组。一个字的位数(即字长脱孩京医握止心绿引)是计算机系统结构长突怎述级烈图理中的一个重要特性。
字长在计算机结构和操作的多个方装去系岩毫其画溶面均有体现。剂么阿术计算机中大多数寄存器的大小是一个字长。计算机处理的典型数值也可能是以字长为单位。C助孩PU和内存之间的数据传送单位也通常扬生染器县压钟是一个字长。还有而内存中用于指明一个存储位置的地址也经常是以字长为单位的。
现代计算机的字长通常为16、32、64位。其他曾经使用过的字长有:8、9、12、18、24、36、39、40、48、60位;slab是早期的另一个字长实例。某些最早期的计算机是十进制的而不是二进制的,通常拥有木施套统10位或者12位的十进制数字作为字长,还有一些早期的计算机根本就没有固定字长。
有时候字长被定义为某个特定值是为了与早期的计算机保持兼容。现在个人计算机中最通用的微处理器(例如:Intel的Pentium跟众系列和AMD的Athlon系列)就胡景料绿尼是一个例子。它们中的IA-32构架是早期的具有16位字长妒的Intel 8086构架的扩展。而IA-32处理器仍然支持8086(x86)程序,所以在IA-32中,"字"的含义仍然为16位,尽管事实上它运采坐洲高铁行起来(特别是当默认操作数为3酸早2位时)更像一台32位计算机。类似地,在更新型的x86-64构架中,"字"仍然是16位的,虽然64位操作数更为常见。
在同一时间中处理二进制数的位数叫字长。通常称处理字长为8位数据的CPU叫8位CPU,32位CPU就是在同一时间内处理字长为32位的二进制数据。二进制的每一个0或1是组成二进制的最小单位,称为位(bit).
字长:一般说来,计算机在同一时间内处理的一组二进制数称为一个计算机的"字",而这组二进制数香剧核坚般敌京诉酒济的位数就是"字长"。字长与计算机的功能和用途有来自很大的关系,是计爱两察承兴引研算机的一个重要技术指标。字长直接反映了一台计算机的计算精度,为适应不同的要求及协调运算精度和硬件造价间的关系,大多数计算机均支持变字长价题纸看脱扩混宗视运算,即机内可实现半字长、全字长(或单字长)和双倍字长运算。在其他指标相同时,字长越360百科大计算机的处理数据的速度就呼丝苦河元套侵高终率冲越快。早期的微机字长一般是8位和16位,386以及更高的处理器大多是3选买医概贵2位。目前市面上的计算机的处理我均器大部分已达到6以练4位。
字长由微处理器对外数据通路的数据总线条数决定。
字长是CPU的主要技术指标之一,指的是CPU一次能并行处理的二进制位数,字长总是8的整数倍,通常PC机的字长为16位(早期),32位,64位。
PC机可以通过编程的方法来处理任意大小的数字,但数字越大,PC机就要谁北故花越长的时间来计算。PC机在一次操作中能处理的最大数字是由PC机的字长确定的。
我们先来看一下新演液款油握人脑是如何进行计算的,例如5×6则立即可以得到答案是30题迅转行族然显强维求,但对于55×66,就不可能立即得到正确的答案,这就是说55或66已走声合攻越倍们善热括素队出了人脑的"字长",这是为色片了得出结果,就必须把复杂的问题死妒采离跳蛋算春(如55×66)分解成伤火味轻易于处理的问题(如55×66可分解为50×60,50×6,5×60,5×6),然后志必者伤位形再综合起来,得出结果。
岁在食级宪吃同样PC机也是这样处理问题的,一台16位字长的PC机,可以直接处理2的16次方(65损经粉较胶有拿536)之内的数字,对于超过65536的数字就需要分解的方法来处理。32位pc机比16位机优越的原因就在于它在一次操作中能处理的数字大,32位字长的PC机能直接处理的数字高达40亿(2的32次方),能处理的的数字越大,则操作的次数就越少,从而系统的效率也就越高。
字长诚然,现在CPU大多是64位的,但大多都以32位字长运行,都没能展示它的字长细的优越性,因为它必须与64位软件(如64位的操作系统等)相辅才成,也就是说,字长受软件系统的制约,例如,在32位软件系统中64位字长的CPU只能当32位用。
根据计算机的组织情况,字长单位可能被应用到:
除聚优控更哪板等括 字
在计算机中,一串数码作为一个整体来处理或运算的,称为一笔儿座曲齐食留始周个计算机字,简称字。字通常分为若干个字节(每个字节一般是8位)。在存储器中,通常每个单元存储一个字,因此每个字都是可以寻址的。字的长度用位数来表示。
在计算机的运算器、控在必吗县吃基制器中,通常都是以字为单位进行传送的。字出现在不同的地址其含义是不相同。例如,送往控制器去的字是指令,而送往运算器去的字就是一个数。
字长
字长是指cpu的每个字所包含的位数。根据计算机的不同,字长有固定的和可变的两种。固定字长,即字长度不论什么情况都是固定不变的;可变字长,则在一定范围内,其长度是可变的。
计算的字长是指它一次可处理的二基得板让温草进制数字的数目。计算机处理数据的速率,自然和它一次能加工的位数以及进行运算的快慢有关。如果一台计算机的字长是另一政台计算机的两倍,即使两台计算机的速度相同,在相同的时间内,前者能做的工作是后者的两倍。一般地,大型计算机的字长为32―64位,小型计算机为16―32位,而微型计算机为4一16位。字长是衡量计算机性能的一个重要因素。
字节
字节是指一小组相邻的二进制数码。通常是8位作为一个字节。它是构成信息的一个小单位,并作为一个整体来参加操作,比字小,是构成字的单位。在微句构双游型计算机中,通常用多须干叫少字节来表示存储器的存储除干施凯现织里活律茶距容量。
在设计计算机时,字他他措继小江长的选择是非常重要的。次期状级冷吧题去设计上的考虑倾向于为特定的用途(如地址)设定特定的位长。然而,出于经济的考虑,又应该仅使继黄尽度云米乎宣运用一种尺寸,或者很少的几种与基本尺寸成倍数或分数(约数)别关系的尺寸。这个首选的基本尺寸就成为该构架的字长。
字符的尺寸对于字长的选择也有影响。20世纪60年代中期以前,字符大部分以6位存储;这样最多允许64个字符,因此不能又大写字符。增美缩啊且送时题我短较由于将字长定义成字符尺寸的倍数在处理时间和存储空间上都比较划算,所以这个时期字长也就被定义为6位(在二进制机器上)的倍数。通常的选择是36位字长,这也是适合于浮点数格式的一个长度。
随着IBM360系统的引入--该系统使用8位字符,并支持大小写字母--标准的字符(确切地说:字节)尺寸也转变成为8位。从那以后,字长也自然变成了8的倍数,16、32、64位字长被广泛使用 。
早期的计算机设计中包括所谓的"可变字长"设计。(原文:Early machine designs included some that used what is often termed avariable word length.--译者)。在这类设计中,数字操作数没有固定的长度,它们通过检查某个特殊字符来判断是否结束。这样的机器使用BCD编码表示数字,例如IBM 702、IBM 705、IBM 7080、IBM 7010、UNIVAC 1050、IBM 1401和IBM 1620。
大部分这样的机器一次处理一个存储单元,因为每条指令和数据占用的数个单元,所以指令将使用数个周期来读取存储器。这类机器经常因为这个原因变得非常慢。例如,在IBM 1620 Model I上,取指令需要8个周期,只是为了读取12个数字(Model II降低到6个周期,不过如果指令不需要取其中的一个1个地址域的话,可以只需要4个周期;如果两个都不需要,则只需要1个周期)
字长对计算机构架的存储器模式有很大的影响。特别是:通常选择字作为存储器的编址方案,所谓存储器编址方案就是地址码能够指定的最小存储单位。In this approach,编号相邻的存储器字组,其地址编号相差一。在计算机中这样很自然,因为它通常总是要处理以字为单位的数据(或者是以字的倍数)。并且具有让指令可以使用最小的长度来指定一个地址的优点,这样,就可以减少指令长度或者可以定义更多的指令条数。
当计算机很大的工作量是用来处理字节时,通常定义字节作为地址编址单位要比字更好。这样做字符串中的单个字符可以通过地址直接指定。当然,一个字仍然可以被地址访问,但是比起字编址方案,它的地址将使用更多的位数。在这种组织结构中,字长需要被定义为字符长度的整数倍。这种编址方案在IBM 360中被使用,此后即变成计算机设计中最普遍的方案。
数据常常要占用不同大小的存储空间,例如,有些数值比其他的数值要求有更高的精度。通常使用的长度是编址单位(以字为单位编址或以字节为单位编址)的倍数,这个倍数常常是的2的幂。这样做是比较便利的,因为这样的话,将一个处理对象在数组中的索引值转化为这个处理对象的地址只需要进行一个移位操作(这在硬件上只需要进行布线的变化)而不需要进行乘操作。某些时候这样的做法还可以避免除操作。因此,一些现代计算机设计使用的字长(或者其他的操作数)是2的幂乘以字节尺寸。
随着计算机设计日益复杂,一个单一字长的核心作用在计算机架构中已经不那么重要。虽然硬件有能力支持更宽的数据类型,但是在扩展处理器性能时,市场却有强大的压力要求新产品保持向后兼容。因此,在一个新构架的向后兼容的设计中,核心的字长不得不与原始机型的字长共存。原始的字长在未来设计中保持可用,这就构成了字长家族的基础。
这种情形的一个主要的实例是x86系列的设计。原始的8086构架无疑是使用16位字长的。80386在8086的基础上进行了大幅改进,使其基于32位系统构架。如果不用考虑其他因素,它将是32位的,但是作为8086的扩展,它的字长继续被当作16位的。(也因此,有人说80386和它的后继处理器是"32位"的(32-bit),但不是32位字的(32-bit word),原文:As a result of this, one hears of the 80386 and successor processors as being "32-bit", but usually not as having a 32-bit word.--译者)同样的情形最近又发生了,当AMD64构架使64位在系统构架具有主要地位,但是它仍然没有放弃对16位和32位的支持。
因此,今天我们看到的计算机体系结构更多的是基于一个有联系的、类似的字长家族,而不是一个单一的字长体系结构。这些尺寸以整因子(integral factors)--通常是2的幂--互相关联。直接将它们中的任何一个尺寸定义为该系统的字长是武断的,因为这些尺寸的设计可能是因为这一系列体系构架的发展的历史原因,而不是体系自己的最新设计中的特性。
年份 | 计算机 架构 | 字长 | 整数 长度 | 浮点数 长度 | 长度 指令 | 编址单位 | 字符 长度 |
---|---|---|---|---|---|---|---|
1941 | Zuse Z3 | 22 b | – | w | 8 b | w | – |
1942 | ABC | 50 b | w | – | – | – | – |
1944 | Harvard Mark I | 23 d | w | – | 24 b | – | – |
1946 (1948) {1953} | ENIAC (w/Panel #16) {w/Panel #26} | 10 d | w, 2w (w) {w} | – | – (2d, 4d, 6d, 8d) | – – {w} | – |
1951 | UNIVAC I | 12 d | w | – | ½w | w | 1 d |
1952 | IAS machine | 40 b | w | – | ½w | w | 5 b |
1952 | IBM 701 | 36 b | ½w,w | – | ½w | ½w,w | 6 b |
1952 | UNIVAC 60 | nd | 1d, ... 10d | – | – | – | 2d, 3d |
1953 | IBM 702 | nd | 0d, ... 511d | – | 5d | d | 1 d |
1953 | UNIVAC 120 | nd | 1d, ... 10d | – | – | – | 2d, 3d |
1954 (1955) | IBM 650 (w/IBM 653) | 10 d | w | – (w) | w | w | 2 d |
1954 | IBM 704 | 36 b | w | w | w | w | 6 b |
1954 | IBM 705 | nd | 0d, ... 255d | – | 5d | d | 1 d |
1954 | IBM NORC | 16 d | w | w, 2w | w | w | – |
1956 | IBM 305 | nd | 1d, ... 100d | – | 10d | d | 1 d |
1958 | UNIVAC II | 12 d | w | – | ½w | w | 1 d |
1958 | SAGE | 32 b | ½w | – | w | w | 6 b |
1958 | Autonetics Recomp II | 40 b | w, 79 b, 8d, 15d | 2w | ½w | ½w,w | 5 b |
1959 | IBM 1401 | nd | 1d, ... | – | d, 2d, 4d, 5d, 7d, 8d | d | 1 d |
1959 (TBD) | IBM 1620 | nd | 2d, ... | – (4d, ... 102d) | 12d | d | 2 d |
1960 | LARC | 12 d | w, 2w | w, 2w | w | w | 2 d |
1960 | IBM 1410 | nd | 1d, ... | – | d, 2d, 6d, 7d, 11d, 12d | d | 1 d |
1960 | IBM 7070 | 10 d | w | w | w | w,d | 2 d |
1960 | PDP-1 | 18 b | w | – | w | w | 6 b |
1961 | IBM 7030 (Stretch) | 64 b | 1b, ... 64b, 1d, ... 16d | w | ½w,w | b, ½w,w | 1 b, ... 8 b |
1961 | IBM 7080 | nd | 0d, ... 255d | – | 5d | d | 1 d |
1962 | UNIVAC III | 25 b, 6 d | w, 2w, 3w, 4w | – | w | w | 6 b |
1962 | UNIVAC 1107 | 36 b | /6w, ⅓w, ½w,w | w | w | w | 6 b |
1962 | IBM 7010 | nd | 1d, ... | – | d, 2d, 6d, 7d, 11d, 12d | d | 1 d |
1962 | IBM 7094 | 36 b | w | w, 2w | w | w | 6 b |
1963 | Gemini Guidance Computer | 39 b | 26 b | – | 13 b | 13 b, 26 b | – |
1963 (1966) | Apollo Guidance Computer | 15 b | w | – | w, 2w | w | – |
1964 | CDC 6600 | 60 b | w | w | ¼w, ½w | w | 6 b |
1965 | IBM 360 | 32 b | ½w,w, 1d, ... 16d | w, 2w | ½w,w, 1½w | 8 b | 8 b |
1965 | UNIVAC 1108 | 36 b | /6w, ¼w, ⅓w, ½w,w, 2w | w, 2w | w | w | 6 b, 9 b |
1965 | PDP-8 | 12 b | w | – | w | w | 8 b |
1970 | PDP-11 | 16 b | w | 2w, 4w | w, 2w, 3w | 8 b | 8 b |
1971 | Intel 4004 | 4 b | w,d | – | 2w, 4w | w | – |
1972 | Intel 8008 | 8 b | w, 2d | – | w, 2w, 3w | w | 8 b |
1972 | Calcomp 900 | 9 b | w | – | w, 2w | w | 8 b |
1974 | Intel 8080 | 8 b | w, 2w, 2d | – | w, 2w, 3w | w | 8 b |
1975 | Cray-1 | 64 b | 24 b,w | w | ¼w, ½w | w | 8 b |
1975 | Motorola 6800 | 8 b | w, 2d | – | w, 2w, 3w | w | 8 b |
1975 | MOS Tech. 6501 MOS Tech. 6502 | 8 b | w, 2d | – | w, 2w, 3w | w | 8 b |
1976 | Zilog Z80 | 8 b | w, 2w, 2d | – | w, 2w, 3w, 4w, 5w | w | 8 b |
1978 (1980) | Intel 8086 (w/Intel 8087) | 16 b | ½w,w, 2d (w, 2w, 4w) | – (2w, 4w, 5w, 17d) | ½w,w, ... 7w | 8 b | 8 b |
1978 | VAX-11/780 | 32 b | ¼w, ½w,w, 1d, ... 31d, 1b, ... 32b | w, 2w | ¼w, ... 14¼w | 8 b | 8 b |
1979 | Motorola 68000 | 32 b | ¼w, ½w,w, 2d | – | ½w,w, ... 7½w | 8 b | 8 b |
1982 (1983) | Motorola 68020 (w/Motorola 68881) | 32 b | ¼w, ½w,w, 2d | – (w, 2w, 2½w) | ½w,w, ... 7½w | 8 b | 8 b |
1985 | ARM1 | 32 b | w | – | w | 8 b | 8 b |
1985 | MIPS | 32 b | ¼w, ½w,w | w, 2w | w | 8 b | 8 b |
1989 | Intel 80486 | 16 b | ½w,w, 2d w, 2w, 4w | 2w, 4w, 5w, 17d | ½w,w, ... 7w | 8 b | 8 b |
1989 | Motorola 68040 | 32 b | ¼w, ½w,w, 2d | w, 2w, 2½w | ½w,w, ... 7½w | 8 b | 8 b |
1991 | PowerPC | 32 b | ¼w, ½w,w | w, 2w | w | 8 b | 8 b |
2000 | IA-64 | 64 b | 8 b, ¼w, ½w,w | ½w,w | 41 b | 8 b | 8 b |
2002 | XScale | 32 b | w | w, 2w | ½w,w | 8 b | 8 b |
说明:b:位, d: 10进制数,w:该构架的字长,n:变量长度(variable size) |
双倍字长是指计算机内部参与运算的数的位数。它决定着计算机内部寄存器、ALU和数据总线的位数,直接影响着机器的硬件规模和造价。双倍字长直接反映了一台计算机的计算精度,为适应不同的要求及协调运算精度和硬件造价间的关系,大多数计算机均支持变字长运算,即机内可实现半字长、全字长(或单字长)和双倍字长运算。
微型机的字长通常为4位、8位、16位和32位,64位字长的高性能微型计算机也已推出。
双倍字长对计算机计算精度的影响:
4位字长:2^4=16;16位字长:2^16=65536=64K
32位字长:2^32=4,294,967,296=4G;64位字长:2^64≈1.8445×10^19
数据总线DB用于传送数据信息。数据总线是双向三态形式的总线,即他既可以把CPU的数据传送到存储器或I/O接口等其它部件,也可以将其它部件的数据传送到CPU。数据总线的位数是微型计算机的一个重要指标,通常与微处理的字长相一致。例如Intel8086微处理器字长16位,其数据总线宽度也是16位。需要指出的是,数据的含义是广义的,它可以是真正的数据,也可以指令代码或状态信息,有时甚至是一个控制信息,因此,在实际工作中,数据总线上传送的并不一定仅仅是真正意义上的数据。
地址总线AB是专门用来传送地址的,由于地址只能从CPU传向外部存储器或I/O端口,所以地址总线总是单向三态的,这与数据总线不同。地址总线的位数决定了CPU可直接寻址的内存空间大小,比如8位微机的地址总线为16位,则其最大可寻址空间为2^16=64KB,16位微型机的地址总线为20位,其可寻址空间为2^20=1MB。一般来说,若地址总线为n位,则可寻址空间为2^(n-10)千字节。
控制总线CB用来传送控制信号和时序信号。控制信号中,有的是微处理器送往存储器和I/O接口电路的,如读/写信号,片选信号、中断响应信号等;也有是其它部件反馈给CPU的,比如:中断申请信号、复位信号、总线请求信号、限备就绪信号等。因此,控制总线的传送方向由具体控制信号而定,一般是双向的,控制总线的位数要根据系统的实际控制需要而定。实际上控制总线的具体情况主要取决于CPU