1.自动机、图灵状态机和状态模式
2.什么是机源模拟器?
3.电子计算机最主要的工作原理是什么
自动机、状态机和状态模式
自动机、码图状态机与状态模式概述
在深入探讨有限自动机与状态模式之前,灵机我们先回顾一下它们在计算机科学领域中的代码应用背景。有限自动机作为一种数学模型,图灵红进源码常用于描述系统的机源状态与状态间的转换,而状态模式则是码图一种面向对象的设计模式,用于管理对象在不同状态下的灵机行为变化。两者虽然在概念上存在关联,代码但各自侧重的图灵领域和应用有所不同。
有限自动机简介
自动机理论是机源计算机科学中的一个核心概念,包括确定性有限自动机(DFA)和非确定性有限自动机(NFA),码图以及推理自动机(PDA)和图灵机等。灵机自动机理论广泛应用于编译器设计、代码正则表达式匹配、自然语言处理等领域。以词法分析为例,通过自动机理论可以有效地将源代码拆解成一系列token,实现代码解析。
以一段Swift代码为例,自动机词法分析的过程可以分解如下:根据当前状态和输入字符生成新的状态,直至解析出所有token。自动机由以下要素组成:状态、输入符号、转换函数、初始状态和接受状态。
状态机实例解析
状态机是一种用于建模系统行为的抽象模型,通常由一组状态和引起状态转换的事件组成。以自动售货机为例,状态机可以描述其在不同状态下的行为和转换规则,如等待投币、等待选择、出货、退币等。
通过定义一系列状态和事件,状态机能够精确描述系统在不同场景下的行为变化。例如,在“等待投币”状态下,收到“投币”事件后转换到“等待选择”状态。通过这种方式,状态机可以有效地管理复杂系统的状态转换。
状态模式概念与应用
状态模式是一种设计模式,用于管理对象在不同状态下的行为变化。它通过封装状态类,使得客户端对象的行为随状态对象的变化而变化。状态模式适用于状态不多、状态转移简单,但业务逻辑复杂的场景,为状态机提供了一种实现方式。
状态模式包含以下组成部分:状态类、上下文类、状态接口和具体状态类。应用领域广泛,如在自动售货机中,通过状态模式可以清晰地管理其在不同状态下的行为逻辑,实现业务逻辑的复用和扩展。
总结与比较
自动机、状态机与状态模式在概念和应用上虽存在相似之处,但各自侧重的领域和应用场景有所不同。自动机理论侧重于形式语言和计算研究,适用于语言模式处理;状态机广泛应用于工程和软件系统,用于管理系统的状态和行为;状态模式则是一种设计模式,用于封装对象在不同状态下的行为变化。理解这些模式的特点和应用领域,有助于在实际问题中选择合适的工具和方法。
什么是模拟器?
仿真器,或模拟器(英文;emulator、simulator),根据此原理制作的软件又可称为模拟程序,是指主要透过软件模拟硬件处理器的功能和指令系统的程序使计算机或者其他多媒体平台(掌上电脑,手机)能够运行其他平台上的软件。在自动化技术、化学工程中同样使用模拟器这一术语。模拟器多用于电视游戏和街机,也有一些用于掌上电脑。模拟器一般需要ROM才能执行,ROM的最初来源是一些原平台的ROM芯片,通过一些手段将原程序拷贝下来(这个过程一般称之为“dump”)然后利用模拟器加载这些ROM来实现模拟过程。
历史
模拟器的历史很长几乎伴随着计算机发展史,很多模拟器的kitten源码图鉴出现,实际上是为了保存很多年前原始的游戏(程序),不过是在不同的设备上运行。在很多欧美国家,拥有和使用模拟器玩游戏是违法行为。在美国,若收集者没有该游戏的原始电子板、卡带或光碟等的游戏原始载体,都视为违法行为,收集ROM也同样不允许。在中国发布与收集都没有限制,制作模拟器或破解ROM都是网络高手热衷的工作。随着模拟器的发展,游戏ROM也在以极快的速度汉化,中国的网站成为模拟器与ROM的储存基地。
工作原理
模拟器包含很多组件:一个模拟很多原始机器的CPU模拟器;一个把很多街机输入设备,例如按钮、摇杆和其他控制的输入映射到PC上的键盘、摇杆和其他设备的模拟器,以及一个街机显示和声音的模拟器。模拟器唯一缺少的是ROM映像,也就是原始的街机游戏中的程序。制作专门的模拟机器往往是价格高昂与困难的,因此使用计算机来模拟是最廉价及方便的方法。
模拟器种类
街机模拟器 家用机模拟器 手掌机模拟器 电脑模拟器
编辑本段常见的模拟器软件
以下列举出PC常用的家用机/掌机模拟器,完美度是指在游戏模拟速度,画面质量,游戏兼容性,操作复杂度以及持有功能上的一个横向对比,数值仅供参考?
ARC
MAME—最有名的街机模拟器(完美度%) Finalburn Alpha—街机模拟器(完美度%) Callus—CPS街机模拟器(完美度%) Kawaks—街机模拟器(完美度%) Nebula—街机模拟器(完美度%) NeoRAGEx—街机模拟器(完美度%)
DC
nullDC—最有名的DC家用机模拟器(完美度%) Chankast—DC家用机模拟器(完美度%)
PS
Bleem!—PS家用机模拟器(完美度%) VGS—PS家用机模拟器(完美度%) ePSXe—PS家用机模拟器(完美度%) SSSPSX—PS家用机模拟器(完美度%)
SS
GIRIGIRI—世嘉土星家用机模拟器(完美度%) SSF—世嘉土星家用机模拟器(完美度%) YASTUBE—世嘉土星家用机模拟器(完美度%)
PS2
PCSX2—PS2家用机模拟器(完美度%)
GBA
VisualBoyAdvance—GB、GBA手掌机模拟器,实现联机功能(完美度%) NO$GBA—GBA手掌机模拟器(完美度%)(可以用来模拟NDS、GBA游戏)
FC
VirtuaNES—FC家用机模拟器(完美度%) FCEUX—FC家用机模拟器(完美度%) Nestopia—FC家用机模拟器(完美度%)
SFC
ZSNES—SFC家用机模拟器(完美度%)
MD
Gens—MD家用机模拟器(完美度%) Kusion—世嘉多用模拟器(完美度%)(可模拟MD、SCD、GG、SMS等)
NDS
No$gba—DS手掌机模拟器(完美度%) iDeaS—DS手掌机模拟器(完美度%) DeSmuME—DS手掌机模拟器(完美度%)
NGC/WII
Dolphin— NGC、Wii家用机模拟器(完美度%)
XBOX
Cxbx—Xbox家用机模拟器(完美度5%)
PSP
JPCSP—PSP手掌机模拟器(完美度%)
MOBILE
手机顽童—电脑用手机模拟器(完美度%) KEmulator—电脑用手机模拟器(完美度%)
编辑本段计算机科学中的模拟器
计算机模拟器
计算机模拟器(computer simulator)指的是“用计算机模拟计算机的模拟器”。计算机模拟器已被用于在实际发行前调试微程序或者商业应用程序。由于该计算机上的操作都是模拟的,所有信息都可被程序员获取,而模拟的速度、执行等都可以控制。请参阅“虚拟机”词条。
网络游戏服务端模拟器
这种模拟器是通过研究游戏客户端和服务端的封包内容,开发出来的一种能够模拟网络游戏服务端的模拟器。使用这种模拟器,可以在非专业服务器上模拟网络游戏服务端以为网络游戏客户端提供连接和游戏服务。
编辑本段计算机架构模拟器/仿真器
概述
不过,当机器A的硬件和速度超过机器B时,在理论上可以用机器A的指令模拟机器B的指令,那么在应用上,可以将性能较低的机器B中的软件重新利用。“仿真器(emulator)”特指这类软件。目前,一些CPU中也集成有模拟其他架构的CPU的微指令集。这也算是一种仿真器。
误解
由于国内许多人了解到的计算机模拟器(simulator)中大部分都是仿真器(emulator),因此误将“模拟器”一词等同于“仿真器”。下文的游戏模拟器内容中,“模拟器”均特指“仿真器”。
重要的计算机模拟器
年,Mike O'Brien开发了Apple II模拟器AppleWin。它配置有KB的内存,无需磁盘就可以启动(内置BASIC),附带显示内存。该模拟器的开源代码一直延续维护到年。 年,Connectix发布了苹果公司Macintosh(麦金塔)系统上的 Virtual PC,可以用它模拟IBM PC兼容机硬件。年,Connectix将它移植到WINDOWS系统上,一般人看来就是“在PC上模拟PC”的软件。后来Connectix把Virtual PC转卖给MicroSoft公司,由后者发布了商业化的Virtual PC 。年,该软件发布了Virtual PC 版本。 Virtual PC配置较容易上手,但当Mircrosoft接手以后,它就倾向于WINDOWS操作系统,安装WINDOWS操作系统比较容易。与Virtual PC相对应竞争的webcat源码解析软件是EMC公司出品的VMWARE,它从年开始开发。相对来说,VMWARE配置起来麻烦一些。
游戏机模拟器的历史
早在大型计算机时代,由于软件开发费用极为高昂,人们为了达到软件兼容的目的,开发了世界上第一台模拟器,作为新开发的硬件系统的一部分。 在二十世纪九十年代初,国外的爱好者就开始试验制作游戏模拟器。据说在年前后已经有Mega Drive模拟器出现。 年,Marat Fayzullin制作了掌机模拟器Visual Game Boy,而且提供了源代码。 年,Nicola Salmora开始了多种街机模拟器MAME(Multiple Arcade Machine Emulator)的研究。根据MAME网站上的记录,MAME 0.1正式版于.2.5作出。 以上两者,在游戏模拟器的历史中,有里程碑的意义。尤其是后者,发展成开放的团队维护源代码,有不同的开放源代码版本。在后来的十年中,MAME将多种不同的街机模拟器合并在一起。相比起其它的模拟器,可以说是能模拟最多硬件和游戏的模拟器软件。 年到年,超级任天堂(SFC/SNES)模拟器SNES9X及ZSNES相继推出。这两个团队开发的模拟器较受好评,不过后来打起来官司。 年,Bloodlust Software开发的以模拟Capcom的CPS1游戏为主的Callus,以模拟Street Fight II(街霸2)、三国志等名作引起了轰动。另外,Bloodlust Software还开发了任天堂FC/NES模拟器NestIcle、 世嘉Mega Drive模拟器Genecyst 。以当时的技术水平来说,这些模拟器都相当出色。但Bloodlust Software没有继续开发模拟器,也没有公开其源代码。其中Nesticle等家用机模拟器后来被SMYNES等模拟器取代了,但Callus到年初还可以看到它在一些盗版碟上出现,足见其影响力。 年,Anders Nilsson and和Korpela发布了最早实现Neo-Geo系列街机游戏主板模拟的NEORAGE/NEORAGE,以对KOF(拳皇)系列和侍魂系列的支持声名大噪。。 年,David Herpolsheimer和Randy Linden发布了第一个Sony Play Station的模拟器Bleem!,在当时引起轰动。一是之前的模拟器几乎都是免费的,而商业化对其它的开发者理念有一定冲击,二则是Play Staytatoin的硬件水平比较接近当时的PC硬件水平,许多人认为PC要经过几年硬件升级才能支持Play Staytatoin模拟器。由于作者后来受到Sony的诉讼,Bleem!逐渐湮没在历史的长河中。 年,Jabo和Zilmar发布了Nintendo 模拟器Project ,比年Episilon和RealityMan发布的第一个Nintendo 模拟器UltraHLENintendo 更为成熟和完善。 年,Forgotten发布了掌机GBA模拟器VisualBoyAdvance的最后一个测试版本。
比较常见的游戏机模拟器
街机模拟器:MAME、WinKawaks、Callus、Rage、Raine、Zinc、neoragex、nebula、kawaks、Calice、Finalburn
街机游戏模拟器(张) FC模拟器:Nestopia、NNNesterJ、VirtuaNES、DreamNES、Smynes、FCEU SFC模拟器:ZSNES、socketio源码解析Snes9X、SNEeSe、uosnesw N模拟器:Project、、UltraHLE、Mupen、Rice PCE模拟器:MagicEngine、YAME SMS/GG模拟器:Dega MD/X/CD模拟器:Gens、Gens、MEKA、Kega Fusion、Ages、Gens LDU SS模拟器:SSF、Yabause、GiriGiri DC模拟器:ChanKast、NullDC PS/PS2模拟器:Bleem!、VGS、ePSXe、PSXeven、PCSX、PCSX2 NGC/WII模拟器:Dolphin GB/GBC/SGB模拟器:VisualBoyKiGB GBA模拟器:VisualBoyAdvance、No$GBA、DreamGBA GG模拟器:MEKA,Mekarnosan WS/WSC模拟器:Cygne、WSCamp、Oswan NGP模拟器:NeoPop、Koyote、NGPocket NDS模拟器:NO$GBA、DeSmuME、Ideas PSP模拟器:Jpcsp、pcsp DOS模拟器:DOSBOX
编辑本段驾驶模拟器
驾驶模拟器是模拟驾驶体验的机械装置,用于在室内训练驾驶员。驾驶员不会因模拟驾驶中的事故而受伤。
飞行模拟器
飞行模拟器常用于训练飞行员在极端险恶的条件下驾驶飞行器。例如不用引擎迫降、电气设备或者液压装置全部失灵等。最先进的飞行模拟器拥有高度真实的视觉系统和液压运动系统。飞行模拟器的运行费用往往低于真实教练机的实际操作费用。
航海模拟器
类似于飞行模拟器,航海模拟器用于训练船员。最常见的航海模拟器有舰桥模拟器、引擎室模拟器、装卸模拟器和通讯/GMDSS模拟器等。航海模拟器主要应用于海事学院、训练机构和海军。
计算器模拟器
计算器在出厂时,需要为其编写用户说明书。其中的截图,都是有计算器模拟器获得而来。在计算机上,计算器模拟器作为一个应用程序,运行快,优点多,也算式一种实用的工具。
电子计算机最主要的工作原理是什么
电子计算机(以下简称计算机)是一种根据一系列指令来对数据进行处理的机器。俗称“电脑”。
计算机种类繁多。实际来看,计算机总体上是处理信息的工具。根据图灵机理论,一部具有最基本功能的计算机应当能够完成任何其它计算机能做的事情。
因此,只要不考虑时间和存储因素,从个人数字助理(PDA)到超级计算机都应该可以完成同样的作业。即是说,即使是设计完全相同的计算机,只要经过相应改装,就应该可以被用于从公司薪金管理到无人驾驶飞船操控在内的各种任务。由于科技的飞速进步,下一代计算机总是在性能上能够显著地超过其前一代,这一现象有时被称作“摩尔定律”。
计算机在组成上形式不一。早期计算机的体积足有一间房屋大小,而今天某些嵌入式计算机可能比一副扑克牌还小。当然,即使在今天,依然有大量体积庞大的巨型计算机为特别的科学计算或面向大型组织的事务处理需求服务。比较小的,为个人应用而设计的计算机称为微型计算机,简称微机。
我们今天在日常使用“计算机”一词时通常也是ARM核源码指此。不过,现在计算机最为普遍的应用形式却是嵌入式的。嵌入式计算机通常相对简单,体积小,并被用来控制其它设备—无论是飞机,工业机器人还是数码相机。
上述对于电子计算机的定义包括了许多能计算或是只有有限功能的特定用途的设备。
然而当说到现代的电子计算机,其最重要的特征是,只要给予正确的指示,任何一台电子计算机都可以模拟其他任何计算机的行为(只受限于电子计算机本身的存储容量和执行的速度)。据此,现代电子计算机相对于早期的电子计算机也被称为通用型电子计算机。
历史
ENIAC 是电脑发展史上的一个里程碑本来,计算机的英文原词"computer" 是指从事数据计算的人。
而他们往往都需要借助某些机械计算设备或模拟计算机。这些早期计算设备的祖先包括有算盘,以及可以追溯到公元前年的被古希腊人用于计算行星移动的Antikythera mechanism。随着中世纪末期欧洲数学与工程学的再次繁荣,Wilhelm Schickard于 年率先研制出了欧洲第一台计算设备。
年,Joseph Marie Jacquard对织布机的设计进行了改进,其中他使用了一系列打孔的纸卡片来作为编织复杂图案的程序。Jacquard 式织布机,尽管并不被认为是一台真正的计算机,但是它的出现确实是现代计算机发展过程中重要的一步。
查尔斯?巴比奇(Charles Babbage)是构想和设计一台完全可编程计算机的第一人,当时是年。但由于技术条件,经费限制,以及无法忍耐对设计不停的修补,这台计算机在他有生之年始终未能问世。约到世纪晚期,许多后来被证明对计算机科学有着重大意义的技术相继出现,包括打孔卡片以及真空管。
Hermann Hollerith设计了一台制表用的机器,就实现了应用打孔卡片的大规模自动数据处理。
在世纪前半叶,为了迎合科学计算的需要,许许多多单一用途的并不断深化复杂的模拟计算机被研制出来。这些计算机都是用它们所针对的特定问题的机械或电子模型作为计算基础。
世纪3,年代,计算机的性能逐渐强大并且通用性得到提升,现代计算机的关键特色被不断地加入进来。
克劳德?香农(Claude Shannon)于年发表了他的伟大论文《对继电器和开关电路中的符号分析》,文中首次提及数字电子技术的应用。
他向人们展示了如何使用开关来实现逻辑和数学运算。此后,他通过研究Vannevar Bush的微分模拟器进一步巩固了他的想法。这是一个标志着二进制电子电路设计和逻辑门应用开始的重要时刻,而作为这些关键思想诞生的先驱,应当包括:Almon Strowger,他为一个含有逻辑门电路的设备申请了专利;尼古拉?特斯拉(Nikola Tesla),他早在年就曾申请含有逻辑门的电路设备;Lee De Forest,于年他用真空管代替了继电器。
沿着这样一条上下求索的漫漫长途去定义所谓的“第一台电子计算机”可谓相当困难。年5月日,Konrad Zuse完成了他的机电共享设备“Z3”,这是第一台具有自动二进制数学计算特色以及可行的编程功能的计算机,但还不是“电子”计算机。
此外,其他值得注意的成就主要有:年夏天诞生的Atanasoff-Berry计算机,这是一台具有特定意图的计算机,但它使用了真空管计算器,二进制数值,可复用内存;在英国于年被展示的神秘的巨像计算机(Colossus computer),尽管编程能力极其有限,但是它的的确确告诉了人们使用真空管既值得信赖又能实现电气化的再编程;哈佛大学的Harvard Mark I;以及基于二进制的“埃尼爱克”(ENIAC,年),这是第一台通用意图的计算机,但由于其结构设计不够弹性化,导致对它的每一次再编程都意味着电气物理线路的再连接。
开发埃尼爱克的小组针对其缺陷又进一步完善了设计,并最终呈现出今天我们所熟知的冯?诺伊曼体系结构(程序存储体系结构)。这个体系是当今所有计算机的基础。世纪年代中晚期,大批基于此一体系的计算机开始被研制,其中以英国最早。
尽管第一台研制完成并投入运转的是“小规模实验机”(Small-Scale Experimental Machine,SSEM),但真正被开发出来的实用机很可能是EDSAC。
在整个世纪年代,真空管计算机居于统治地位。
到了年代,晶体管计算机将其取而代之。晶体管体积更小,速度更快,价格更加低廉,性能更加可靠,这使得它们可以被商品化生产。到了年代,集成电路技术的引入极大地降低了计算机生产成本,计算机也从此开始走向千家万户。
[编辑] 原理
个人电脑的主要结构:
显示器
主板
CPU (微处理器)
主要储存器 (内存)
扩充卡
电源供应器
光驱
次要储存器 (硬盘)
键盘
鼠标
尽管计算机技术自世纪年代第一台电子通用计算机诞生以来以来有了令人目眩的飞速发展,但是今天计算机仍然基本上采用的是存储程序结构,即冯?诺伊曼体系结构。
这个结构实现了实用化的通用计算机。
存储程序结构间将一台计算机描述成四个主要部分:算术逻辑单元(ALU),控制电路,存储器,以及输入输出设备(I/O)。这些部件通过一组一组的排线连接(特别地,当一组线被用于多种不同意图的数据传输时又被称为总线),并且由一个时钟来驱动(当然某些其他事件也可能驱动控制电路)。
概念上讲,一部计算机的存储器可以被视为一组“细胞”单元。每一个“细胞”都有一个编号,称为地址;又都可以存储一个较小的定长信息。这个信息既可以是指令(告诉计算机去做什么),也可以是数据(指令的处理对象)。原则上,每一个“细胞”都是可以存储二者之任一的。
算术逻辑单元(ALU)可以被称作计算机的大脑。它可以做两类运算:第一类是算术运算,比如对两个数字进行加减法。算术运算部件的功能在ALU中是十分有限的,事实上,一些ALU根本不支持电路级的乘法和除法运算(由是使用者只能通过编程进行乘除法运算)。
第二类是比较运算,即给定两个数,ALU对其进行比较以确定哪个更大一些。
输入输出系统是计算机从外部世界接收信息和向外部世界反馈运算结果的手段。对于一台标准的个人电脑,输入设备主要有键盘和鼠标,输出设备则是显示器,打印机以及其他许多后文将要讨论的可连接到计算机上的I/O设备。
控制系统将以上计算机各部分联系起来。它的功能是从存储器和输入输出设备中读取指令和数据,对指令进行解码,并向ALU交付符合指令要求的正确输入,告知ALU对这些数据做那些运算并将结果数据返回到何处。控制系统中一个重要组件就是一个用来保持跟踪当前指令所在地址的计数器。
通常这个计数器随着指令的执行而累加,但有时如果指令指示进行跳转则不依此规则。
世纪年代以来ALU和控制单元(二者合成中央处理器,CPU)逐渐被整合到一块集成电路上,称作微处理器。这类计算机的工作模式十分直观:在一个时钟周期内,计算机先从存储器中获取指令和数据,然后执行指令,存储数据,再获取下一条指令。
这个过程被反复执行,直至得到一个终止指令。
由控制器解释,运算器执行的指令集是一个精心定义的数目十分有限的简单指令集合。一般可以分为四类:1)、数据移动(如:将一个数值从存储单元A拷贝到存储单元B)2)、数逻运算(如:计算存储单元A与存储单元B之和,结果返回存储单元C)3)、条件验证(如:如果存储单元A内数值为,则下一条指令地址为存储单元F)4)、指令序列改易(如:下一条指令地址为存储单元F)
指令如同数据一样在计算机内部是以二进制来表示的。
比如说,就是一条Intel x系列微处理器的拷贝指令代码。某一个计算机所支持的指令集就是该计算机的机器语言。因此,使用流行的机器语言将会使既成软件在一台新计算机上运行得更加容易。所以对于那些机型商业化软件开发的人来说,它们通常只会关注一种或几种不同的机器语言。
更加强大的小型计算机,大型计算机和服务器可能会与上述计算机有所不同。它们通常将任务分担给不同的CPU来执行。今天,微处理器和多核个人电脑也在朝这个方向发展。
超级计算机通常有着与基本的存储程序计算机显著区别的体系结构。
它们通常由者数以千计的CPU,不过这些设计似乎只对特定任务有用。在各种计算机中,还有一些微控制器采用令程序和数据分离的哈佛体系结构(Harvard architecture)。
[编辑] 计算机的数字电路实现
以上所说的这些概念性设计的物理实现是多种多样的。
如同我们所前述所及,一台存储程序式计算机既可以是巴比奇的机械式的,也可以是基于数字电子的。但是,数字电路可以通过诸如继电器之类的电子控制开关来实现使用2进制数的算术和逻辑运算。香农的论文正是向我们展示了如何排列继电器来组成能够实现简单布尔运算的逻辑门。
其他一些学者很快指出使用真空管可以代替继电器电路。真空管最初被用作无线电电路中的放大器,之后便开始被越来越多地用作数字电子电路中的快速开关。当电子管的一个针脚被通电后,电流就可以在另外两端间自由通过。
通过逻辑门的排列组合我们可以设计完成很多复杂的任务。
举例而言,加法器就是其中之一。该器件在电子领域实现了两个数相加并将结果保存下来—在计算机科学中这样一个通过一组运算来实现某个特定意图的方法被称做一个算法。最终,人们通过数量可观的逻辑门电路组装成功了完整的ALU和控制器。说它数量可观,只需看一下CSIRAC这台可能是最小的实用化电子管计算机。
该机含有个电子管,其中还有不少是双用器件,也即是说总计合有到个逻辑器件。
真空管对于制造规模庞大的门电路明显力不从心。昂贵,不稳(尤其是数量多时),臃肿,能耗高,并且速度也不够快—尽管远超机械开关电路。
这一切导致世纪年代它们被晶体管取代。后者体积更小,易于操作,可靠性高,更省能耗,同时成本也更低。
集成电路是现今电子计算机的基础世纪年代后,晶体管开始逐渐为将大量晶体管、其他各种电器元件和连接导线安置在一片硅板上的集成电路所取代。
年代,ALU和控制器作为组成CPU的两大部分,开始被集成到一块芯片上,并称为“微处理器”。沿着集成电路的发展史,可以看到一片芯片上所集成器件的数量有了飞速增长。第一块集成电路只不过包含几十个部件,而到了年,一块Intel Core Duo 处理器上的晶体管数目高达一亿五千一百万之巨。
无论是电子管,晶体管还是集成电路,它们都可以通过使用一种触发器设计机制来用作存储程序体系结构中的“存储”部件。而事实上触发器的确被用作小规模的超高速存储。但是,几乎没有任何计算机设计使用触发器来进行大规模数据存储。最早的计算机是使用Williams电子管向一个电视屏或若干条水银延迟线(声波通过这种线时的走行速度极为缓慢足够被认为是“存储”在了上面)发射电子束然后再来读取的方式来存储数据的。
当然,这些尽管有效却不怎么优雅的方法最终还是被磁性存储取而代之。比如说磁芯存储器,代表信息的电流可在其中的铁质材料内制造恒久的弱磁场,当这个磁场再被读出时就实现了数据恢复。动态随机存储器(DRAM)亦被发明出来。它是一个包含大量电容的集成电路,而这些电容器件正是负责存储数据电荷—电荷的强度则被定义为数据的值。
[编辑] 输入输出设备
输入输出设备(I/O)是对将外部世界信息发送给计算机的设备和将处理结果返回给外部世界的设备的总称。这些返回结果可能是作为使用者能够视觉上体验的,或是作为该计算机所控制的其他设备的输入:对于一台机器人,控制计算机的输出基本上就是这台机器人本身,如做出各种行为。
第一代计算机的输入输出设备种类非常有限。通常的输入用设备是打孔卡片的读卡机,用来将指令和数据导入内存;而用于存储结果的输出设备则一般是磁带。随着科技的进步,输入输出设备的丰富性得到提高。以个人计算机为例:键盘和鼠标是用户向计算机直接输入信息的主要工具,而显示器、打印机、扩音器、耳机则返回处理结果。
此外还有许多输入设备可以接受其他不同种类的信息,如数码相机可以输入图像。在输入输出设备中,有两类很值得注意:第一类是二级存储设备,如硬盘,[[光盘]]或其他速度缓慢但拥有很高容量的设备。第二个是计算机网络访问设备,通过他们而实现的计算机间直接数据传送极大地提升了计算机的价值。
今天,国际互联网成就了数以千万计的计算机彼此间传送各种类型的数据。
[编辑] 程序
简单说,计算机程序就是计算机执行指令的一个序列。它既可以只是几条执行某个简单任务的指令,也可能是可能要操作巨大数据量的复杂指令队列。
许多计算机程序包含有百万计的指令,而其中很多指令可能被反复执行。在年,一台典型的PC机可以每秒执行大约亿条指令。计算机通常并不会执行一些很复杂的指令来获得额外的机能,更多地它们是在按照程序员的排列来运行那些较简单但为数众多的短指令。
一般情况下,程序员们是不会直接用机器语言来为计算机写入指令的。那么做的结果只能是费时费力、效率低下而且漏洞百出。所以,程序员一般通过“高级”一些的语言来写程序,然后再由某些特别的计算机程序,如解释器或编译器将之翻译成机器语言。
一些编程语言看起来很接近机器语言,如汇编程序,被认为是低级语言。而另一些语言,如即如抽象原则的Prolog,则完全无视计算机实际运行的操作细节,可谓是高级语言。对于一项特定任务,应该根据其事务特点,程序员技能,可用工具和客户需求来选择相应的语言,其中又以客户需求最为重要(美国和中国军队的工程项目通常被要求使用Ada语言)。
计算机软件是与计算机程序并不相等的另一个词汇。计算机软件一个较为包容性较强的技术术语,它包含了用于完成任务的各种程序以及所有相关材料。举例说,一个视频游戏不但只包含程序本身,也包括、声音以及其他创造虚拟游戏环境的数据内容。
在零售市场,在一台计算机上的某个应用程序只是一个面向大量用户的软件的一个副本。这里老生常谈的例子当然还是微软的office软件组,它包括一些列互相关联的、面向一般办公需求的程序。
利用那些极其简单的机器语言指令来实现无数功能强大的应用软件意味着其编程规模注定不小。
Windows XP这个操作系统程序包含的C 高级语言源代码达到了万行。当然这还不是最大的。如此庞大的软件规模也显示了管理在开发过程中的重要性。实际编程时,程序会被细分到每一个程序员都可以在一个可接受的时长内完成的规模。
即便如此,软件开发的过程仍然进程缓慢,不可预见且遗漏多多。
应运而生的软件工程学就重点面向如何加快作业进度和提高效率与质量。
[编辑] 库与操作系统
在计算机诞生后不久,人们发现某些特定作业在许多不同的程序中都要被实施,比如说计算某些标准数学函数。
出于效率考量,这些程序的标准版本就被收集到一个“库”中以供各程序调用。许多任务经常要去额外处理种类繁多的输入输出接口,这时,用于连接的库就能派上用场。
世纪年代,随着计算机工业化普及,计算机越来越多地被用作一个组织内不同作业的处理。
很快,能够自动安排作业时续和执行的特殊软件出现了。这些既控制硬件又负责作业时序安排的软件被称为“操作系统”。一个早期操作系统的例子是IBM的OS/。
在不断地完善中,操作系统又引入了时间共享机制——并发。这使得多个不同用户可以“同时”地使用机器执行他们自己的程序,看起来就像是每个人都有一台自己的计算机。
为此,操作系统需要像每个用户提供一台“虚拟机”来分离各个不同的程序。由于需要操作系统控制的设备也在不断增加,其中之一便是硬盘。因之,操作系统又引入了文件管理和目录管理(文件夹),大大简化了这类永久储存性设备的应用。此外,操作系统也负责安全控制,确保用户只能访问那些已获得允许的文件。
当然,到目前为止操作系统发展历程中最后一个重要步骤就是为程序提供标准图形用户界面(GUI)。尽管没有什么技术原因表明操作系统必须得提供这些界面,但操作系统供应商们总是希望并鼓励那些运行在其系统上的软件能够在外观和行为特征上与操作系统保持一致或相似。
除了以上这些核心功能,操作系统还封装了一系列其他常用工具。其中一些虽然对计算机管理并无重大意义,但是于用户而言很是有用。比如,苹果公司的Mac OS X就包含视频剪辑应用程序。
一些用于更小规模的计算机的操作系统可能没用如此众多的功能。
早期的微型计算机由于内存和处理能力有限而不会提供额外功能,而嵌入式计算机则使用特定化了的操作系统或者干脆没有,它们往往通过应用程序直接代理操作系统的某些功能。
[编辑] 应用
由电脑控制的机械在工业中十分常见 很多现代大量生产的玩具,如Furby,是不能没有便宜的嵌入式处理器
起初,体积庞大而价格昂贵的数字计算机主要是用做执行科学计算,特别是军用课题。
如ENIAC最早就是被用作火炮弹道计算和设计氢弹时计算断面中子密度的(如今许多超级计算机仍然在模拟核试验方面发挥着巨大作用)。澳大利亚设计的首台存储程序计算机CSIR Mk I型负责对水电工程中的集水地带的降雨情形进行评估。还有一些被用于解密,比如英国的“巨像”可编程计算机。
除去这些早年的科学或军工应用,计算机在其他领域的推广亦十分迅速。
从一开始,存储程序计算机就与商业问题的解决息息相关。早在IBM的第一台商用计算机诞生之前,英国J。 Lyons等就设计制造了LEO以进行资产管理或迎合其他商业用途。
由于持续的体积与成本控制,计算机开始向更小型的组织内普及。加之世纪年代微处理器的发明,廉价计算机成为了现实。年代,个人计算机全面流行,电子文档写作与印刷,计算预算和其他重复性的报表作业越来越多地开始依赖计算机。
随着计算机便宜起来,创作性的艺术工作也开始使用它们。
人们利用合成器,计算机图形和动画来创作和修改声音,图像,视频。视频游戏的产业化也说明了计算机在娱乐方面也开创了新的历史。
计算机小型化以来,机械设备的控制也开始仰仗计算机的支持。其实,正是当年为了建造足够小的嵌入式计算机来控制阿波罗宇宙飞船才刺激了集成电路技术的跃进。
今天想要找一台不被计算机控制的有源机械设备要比找一台哪怕是部分计算机控制的设备要难得多。可能最著名的计算机控制设备要非机器人莫属,这些机器有着或多或少人类的外表和并具备人类行为的某一子集。在批量生产中,工业机器人已是寻常之物。不过,完全的拟人机器人还只是停留在科幻小说或实验室之中。
机器人技术实质上是人工智能领域中的物理表达环节。所谓人工智能是一个定义模糊的概念但是可以肯定的是这门学科试图令计算机拥有目前它们还没有但作为人类却固有的能力。数年以来,不断有许多新方法被开发出来以允许计算机做那些之前被认为只有人才能做的事情。
比如读书、下棋。然而,到目前为止,在研制具有人类的一般“整体性”智能的计算机方面,进展仍十分缓慢。
[编辑] 网络、国际互联网
世纪年代以来计算机开始用作协调来自不同地方之信息的工具,美国军方的贤者系统(SAGE)就是这方面第一个大规模系统。
之后“军刀”等一系列特殊用途的商业系统也不断涌现出来。
年代后,美国各大院校的计算机工程师开始使用电信技术把他们的计算机连接起来。由于这方面的工作得到了ARPA的赞助,其计算机网络也就被称为ARPANET。此后,用于ARPA网的技术快速扩散和进化,这个网络也冲破大学和军队的范围最终形成了今天的国际互联网(Internet)。
网络的出现导致了对计算机属性和边界的再定义。太阳微系统公司的John Gage 和 Bill Joy就指出:“网络即是计算机”。计算机操作系统和应用程序纷纷向能访问诸如网内其它计算机等网络资源的方向发展。最初这些网络设备仅限于为高端科学工作者所使用,但年代后随着电子邮件和万维网(World Wide Web)技术的扩散,以及以太网和ADSL等网络连接技术的廉价化,互联网络已变得无所不在。
今日入网的计算机总数,何以千万计;无线互联技术的普及,使得互联网在移动计算环境中亦如影随形。比如在笔记本计算机上广泛使用的Wi-Fi技术就是无线上网的代表性应用。
[编辑] 下一代计算机
尽管自问世以来数字计算机在速度和能力上有了可观的提升,迄今仍有不少课题显得超出了当前计算机的能力所及。
对于其中一部分课题,传统计算机是无论如何也不可能实现的,因为找到一个解决方法的时间还赶不上问题规模的扩展速度。因此,科学家开始将目光转向生物计算技术和量子理论来解决这一类问题。比如,人们计划用生物性的处理来解决特定问题(DNA计算)。由于细胞分裂的指数级增长方式,DNA计算系统很有可能具备解决同等规模问题的能力。
当然,这样一个系统直接受限于可控制的DNA总量。
量子计算机,顾名思义,利用了量子物理世界的超常特性。一旦能够造出量子计算机,那么它在速度上的提升将令一般计算机难以望其项背。当然,这种涉及密码学和量子物理模拟的下一代计算机还只是停留在构想阶段。
上述的计算机目前都还未成型,并且即使成功制造出来,它们也很有可能只会被用作解决那些普通计算机无法解决的问题。
[编辑] 计算机学科
在当今世界,几乎所有专业都与计算机息息相关。
但是,只有某些特定职业和学科才会深入研究计算机本身的制造、编程和使用技术。用来诠释计算机学科内不同研究领域的各个学术名词的涵义不断发生变化,同时新学科也层出不穷。
计算机工程学 是电子工程的一个分支,主要研究计算机软硬件和二者间的彼此联系。
计算机科学 是对计算机进行学术研究的传统称谓。主要研究计算技术和执行特定任务的高效算法。该门学科为我们解决确定一个问题在计算机领域内是否可解,如可解其效率如何,以及如何作成更加高效率的程序。时至今日,在计算机科学内已经衍生了许多分支,每一个分支都针对不同类别的问题进行深入研究。
软件工程学 着重于研究开发高质量软件系统的方法学和实践方式,并试图压缩并预测开发成本及开发周期。
信息系统 研究计算机在一个广泛的有组织环境(商业为主)中的计算机应用。
许多学科都与其他学科相互交织。
如地理信息系统专家就是利用计算机技术来管理地理信息。
全球有三个较大规模的致力于计算机科学的组织:英国计算机协会 (BCS);美国计算机协会(ACM);美国电气电子工程师协会(IEEE)。