首页编程32位 64位(32位和64位有什么不同)

32位 64位(32位和64位有什么不同)

编程之家2024-05-1177次浏览

一、32位软件和64位软件有什么区别

软件是没有区别的。

32位 64位(32位和64位有什么不同)

32位和64位系统的区别:

1.设计初衷不同。

64位操作系统的设计初衷是:满足机械设计和分析、三维动画、视频编辑和创作,以及科学计算和高性能计算应用程序等领域中需要大量内存和浮点性能的客户需求。换句简明的话说就是:它们是高科技人员使用本行业特殊软件的运行平台。而32位操作系统是为普通用户设计的。

2.要求配置不同。

64位操作系统只能安装在64位电脑上(CPU必须是64位的)。同时需要安装64位常用软件以发挥64位(x64)的最佳性能。 32位操作系统则可以安装在32位(32位CPU)或64位(64位CPU)电脑上。当然,32位操作系统安装在64位电脑上,其硬件恰似“大马拉小车”:64位效能就会大打折扣。

3.运算速度不同。

32位 64位(32位和64位有什么不同)

64位CPU GPRs(General-Purpose Registers,通用寄存器)的数据宽度为64位,64位指令集可以运行64位数据指令,也就是说处理器一次可提取64位数据(只要两个指令,一次提取8个字节的数据),比32位(需要四个指令,一次提取4个字节的数据)提高了一倍,理论上性能会相应提升1倍。

4.寻址能力不同。

64位处理器的优势还体现在系统对内存的控制上。由于地址使用的是特殊的整数,因此一个ALU(算术逻辑运算器)和寄存器可以处理更大的整数,也就是更大的地址。比如,Windows Vista x64 Edition支持多达128 GB的内存和多达16 TB的虚拟内存,而32位CPU和操作系统最大只可支持4G内存。

5.软件普及不同。

目前,64位常用软件比32位常用软件,要少得多的多。道理很简单:使用64位操作系统的用户相对较少。因此,软件开发商必须考虑“投入产出比”,将有限资金投入到更多使用群体的软件之中。这也是为什么64位软件价格相对昂贵的重要原因(将成本摊入较少的发售之中)。

40分享举报

32位 64位(32位和64位有什么不同)

相关问题

二、电脑32位和64位有什么区别

1、通常情况下,计算机的位计数指示计算机可以处理的数据量、处理数据的速度和最大内存容量。为了优化计算机性能,安装在计算机上的操作系统的位计数应该与计算机本身的位计数相匹配。

2、对于程序而言,大多数专门为运行 32位版本 Windows的电脑而设计的程序可以在运行 64位版本 Windows的电脑中正常运行。但是,大多数专门为 64位版本的 Windows设计的程序通常运行速度较快,尤其是当它们执行强化任务(例如,编辑高清晰视频或操作大型数据库)时。

3、对于驱动程序而言,电脑运行的是 64位版本的 Windows,则需要 64位驱动程序,才可将每个硬件安装或连接到电脑。

4、基于 Intel Itanium的计算机只能运行 Windows的 64位版本;基于 Intel Itanium的计算机无法运行 Windows的 32位版本。现在,Windows的 64位版本只能在基于 Itanium和 AMD64的计算机上运行。

5、使用 64位版本 Windows的电脑可利用更多内存(4 GB(千兆字节)或更多),而使用 32位版本 Windows的电脑只能利用 3.5 GB或更少的内存。(即使某台电脑已安装 4 GB或更多内存,但 32位版本的 Windows仍然仅占用其中的 3.5 GB内存。)通过在 RAM中储存更多的进程,最大程度地减少花费在将进程交换出/入存储器上的时间,而这又可以提高程序的整体性能。64位和32位的版本其实就是在读取内存上不同而已。对于大多数人而言它们的区别几乎是体会不到的。

拓展资料:

查看电脑是32位还是64

1、选中我的电脑,点击右键,可以看到”属性“这个选项。

2、点开属性即可看到你的电脑是32位还是64位操作系统。

3、在我的属性上还有一些有关计算机的基本信息,例如处理器、内存等。当你对你的计算机不了解时,就请点开属性看看吧。

三、为什么好多软件都区分32位和64位,到底有什么区别

64位软件和32位软件最大的区别是:64位的软件可以同时操作大于4GB的内存(注意这里的内存指的是地址空间,而不是物理内存)。

比如现在有一个10GB的数据库需要进行排序。64位的软件可以动态的分配一个10GB的空间把整个数据库“放进”内存然后使用任意经典排序算法,而32位的软件在动态分配时就会崩溃。所以32位软件的程序员只能使用复杂的算法显式的分块读入,局部排序,写回数据库,然后重复。这样不仅程序复杂难写,程序员交换内存和文件的算法效率可能也不如操作系统自动处理来的高效。

另一方面,64位软件巨大的内存空间也可能加速物理内存的消耗,增加寻址的开销,因此未必总是能够提高性能。当然最终系统的效率还是取决于物理内存的大小,64位只是解决了地址空间的瓶颈。32位CPU和64位CPU的区别?32位、64位CPU在指令集合、操作数位数、寄存器名称和个数等都不相同。

比如一条mov

eax,1指令,可能在32位CPU上对应的机器指令是0x1201;在64位机器上就是0x123401。程序对于机器CPU而言,仅仅是一系列顺序躺在内存中的01代码而已,而硬件上直接运行的是操作系统,所以你马上得出结论:32位的CPU只能运行32位的操作系统,64位同理。

这么设计的确在理论上没什么不妥,实际上intel

IA

64架构的处理器就是这样的,64位的CPU上只能运行64位的操作系统(操作系统本身也是软件,也是一系列指令序列)。但这样问题就来了:我需要升级硬件来提速,难道买了CPU以后,要把上层的操作系统和应用软件通通换掉?

这种软硬件不兼容带来的问题就是,没有多少客户会去购买这种没法兼容32位原有软件环境的CPU。所以,后来intel和amd都推出了兼容32位原有软件环境的CPU(intel

的x86&64和amd的amd64)。也就是说,现在主流的64位CPU,上面可以运行32位和64位的操作系统。编译器与程序位数编译器也是一个应用软件,64位机器上的64位编译器编译出来的也就是64位的应用软件。

但是有没有例外呢?那第一个64位的操作系统是怎么来的?我们都知道现在操作系统一般是用C语言实现的,然后像普通程序一样经过编译器编译成可执行文件,难道64位的操作系统不是用64位的编译器编译出来的?很显然,你的第一个64位的操作系统,需要用“64位”的编译器来生成,但你的64位的编译器运行在什么操作系统上呢?

当然,我肯定运行在64位的操作系统之上,那你64位的操作系统从哪里来呢?死循环状态中。所以,必然有一种编译器,本身是32位的软件,但能够将程序编译成64位的可执行文件,也只有这种情况下,编译器本身位数和编译出来程序的位数才不一致。

操作系统位数和软件位数的关系这里,我们首先要弄清一个软件是如何被运行的,我们以C文件为例,讨论我们经典的hello

word程序:#include<stdio.h>int main(){printf("hello

world")}一个源程序首先被预处理,寻找头文件,将头文件包括进来,里面有printf的申明。然后被编译成目标文件,注意目标文件已经是二进制文件了,里面的符号表中有main、printf等,但是很显然,这个prinf不是我们自己写的,我们仅仅有它的申明而已。

此时如果我们查看目标文件,就会发现目标文件中的printf函数是extern标记,表示这是一个外部符号,并不是我们定义的。显然,这时目标文件是没法运行的,因为里面有未知符号没有解析。目标文件经过链接,形成可执行目标文件。因为操作系统提供了已经编译好的动态链接库,所以此时我们仅仅经过链接,神奇的hello就能执行了。这样,你是不是没有感觉到你的软件有32位和64位的区别?你管它叫128位都没问题。

但是,上述过过程有几个非常重要的地方:

1)动态链接库

2)系统API首先,你32位的操作系统上一般是没有64位的库文件,如果你的应用程序源代码中引用了只有64位的动态库中才有的函数,很显然你链接的时候就会出问题。

另外,我们很多程序肯定用到了read和write等C语言库函数,而库函数的实现是依赖于系统API的。如果你工作在windows上,程序大多数是以exe形式发布的,你得到的程序是目标文件以后的结果,本身是带有位数的;如果你工作在linux上,本身大部分软件包rpm等也是已经编译好的,就是说,它们本身就是具有“位数”的。

如果你得到的是源码,那么基本上你的应用程序还没有“位数”的概念,你用多少位的编译器去编译它,它就是多少位的应用程序。我们这里讨论多少位的程序,都是针对已经编译到目标文件以后的状态。所以32位和64位软件的并存是CPU、系统、编译综合决定的,而这些都是因为时代的需要。

对于Windows系统而言,64位的系统上往往有32位的库和其他必要的信息,基本上能兼容32位的程序。以上是个人的一些经验和总结,希望可以帮助到大家,如果有不同意见和建议,欢迎评论区留言讨论。

wmi服务(wmi服务是什么)录播服务(什么是录播服务器)