(转) 寄存器、RAM、ROM、Flash相关概念区别整理

转自 http://m.blog.chinaunix.net/uid-30077524-id-5570244.htmlhtml

文章对这几个东西讲得很清楚,值得收藏。git

 

寄存器算法

寄存器是中央处理器内的组成部份。它跟CPU有关。寄存器是有限存贮容量的高速存贮部件,它们可用来暂存指令、数据和位址。在中央处理器的控制部件中,包含的寄存器有指令寄存器(IR)和程序计数器(PC)。在中央处理器的算术及逻辑部件中,包含的寄存器有累加器(ACC)。编程

存储器安全

存储器范围最大,它几乎涵盖了全部关于存储的范畴。你所说的寄存器,内存,都是存储器里面的一种。凡有存储能力的硬件,均可以称之为存储器,这是天然,硬盘更加明显了,它纳入外存储器行列,因而可知——。性能优化

内存dom

内存既专业名上的内存储器,它不是个什么神秘的东西,它也只是存储器中的沧海一粟,它包涵的范围也很大,通常分为只读存储器和随即存储器,以及最强悍的高速缓冲存储器(CACHE),只读存储器应用普遍,它一般是一块在硬件上集成的可读芯片,做用是识别与控制硬件,它的特色是只可读取,不能写入。随机存储器的特色是可读可写,断电后一切数据都消失,咱们所说的内存条就是指它了。性能

CACHE优化

CACHE是在CPU中速度很是块,而容量却很小的一种存储器,它是计算机存储器中最强悍的存储器。因为技术限制,容量很难提高,通常都不过兆。 ui

ROM、RAM的区别:

ROM(只读存储器或者固化存储器)

RAM(随机存取存储器)

ROM和RAM指的都是半导体存储器,ROM是Read Only Memory的缩写,RAM是Random Access Memory的缩写。ROM在系统中止供电的时候仍然能够保持数据,而RAM一般都是在掉电以后就丢失数据,典型的RAM就是计算机的内存。 

RAM有两大类,一种称为静态RAM(Static RAM/SRAM),当数据被存入其中后不会消失。SRAM速度很是快,是目前读写最快的存储设备了。当这个SRAM 单元被赋予0 或者1 的状态以后,它会保持这个状态直到下次被赋予新的状态或者断电以后才会更改或者消失。可是存储1bit 的信息须要4-6 只晶体管。所以它也很是昂贵,因此只在要求很苛刻的地方使用,譬如CPU的一级缓冲,二级缓冲。另外一种称为动态RAM(Dynamic RAM/DRAM),DRAM 必须在必定的时间内不停的刷新才能保持其中存储的数据。DRAM 只要1 只晶体管就能够实现。DRAM保留数据的时间很短,速度也比SRAM慢,不过它仍是比任何的ROM都要快,但从价格上来讲DRAM相比SRAM要便宜很 多,计算机内存就是DRAM的。 

DRAM分为不少种,常见的主要有FPRAM/FastPage、EDORAM、SDRAM、DDR RAM、RDRAM、SGRAM以及WRAM等,这里介绍其中的一种DDR RAM。DDR RAM(Date-Rate RAM)也称做DDR SDRAM,这种改进型的RAM和SDRAM是基本同样的,不一样之处在于它能够在一个时钟读写两次数据,这样就使得数据传输速度加倍了。这是目前电脑中用 得最多的内存,并且它有着成本优点,事实上击败了Intel的另一种内存标准-Rambus DRAM。在不少高端的显卡上,也配备了高速DDR RAM来提升带宽,这能够大幅度提升3D加速卡的像素渲染能力。 

ROM也有不少种,PROM是可编程的ROM,PROM和EPROM(可擦除可编程ROM)二者区别是,PROM是一次性的,也就是软件灌入后,就没法修 改了,这种是早期的产品,如今已经不可能使用了,而EPROM是经过紫外光的照射擦出原先的程序,是一种通用的存储器。另一种EEPROM是经过电子擦出,价格很高,写入时间很长,写入很慢。 

最初,把只能读的存储器叫作ROM(Read Only Memory),而且掉电后数据不会丢失。因为不能改写,于是使用起来很不方便。随着技术的进步,在ROM中使用一些新技术,就可使它具备能够编程的功能。比较早的是熔丝型的可编程ROM,因为是经过熔断熔丝来编程的,因此这类ROM编程后,就不能再写了,是一次性的(OTP)。后来又出现了EPROM,是经过紫外线来擦除的,而且经过高压来编程,这类ROM上面通常有一个透明的石英玻璃窗,看上去挺漂亮的,它就是用来给紫外线照射的。后来又出现了EEPROM,不用紫外线照射就能够擦除,于是能够直接在电路中编程。另外还有FLASH ROM,又可分为NOR FLASH和NAND FLASH。FLASH ROM通常有一个特色,就是写数据时,能够将1改成0,而不能将0改成1,于是写数据前须要擦除,擦除时将全部数据置1。

之因此依然叫作ROM,概括一下,大概有几个缘由:

①不能像RAM那样快速的写;

②可能须要特殊的擦写电压;

③可能须要特殊的擦写时序;

④可能须要在写以前进行擦除操做;

⑤擦写次数有限,不像RAM那样能够随意写而不损坏;

⑥掉电后数据不会丢失;

⑦有些可写的存储器只能写一次(OTP)。

举个例子,手机软件通常放在EEPROM中,咱们打电话,有些最后拨打的号码,暂时是存在SRAM中的,不是立刻写入经过记录(通话记录保存在EEPROM中),由于当时有很重要工做(通话)要作,若是写入,漫长的等待是让用户忍无可忍的。

FLASH存储器又称闪存,它结合了ROM和RAM的长处,不只具有电子可擦出可编程(EEPROM)的性能,还不会断电丢失数据同时能够快速读取数据 (NVRAM的优点),U盘和MP3里用的就是这种存储器。在过去的20年里,嵌入式系统一直使用ROM(EPROM)做为它们的存储设备,然而近年来 Flash全面代替了ROM(EPROM)在嵌入式系统中的地位,用做存储Bootloader以及操做系统或者程序代码或者直接当硬盘使用(U盘)。 

目前Flash主要有两种NOR Flash和NADN Flash。NOR Flash的读取和咱们常见的SDRAM的读取是同样,用户能够直接运行装载在NOR FLASH里面的代码,这样能够减小SRAM的容量从而节约了成本。NAND Flash没有采起内存的随机读取技术,它的读取是以一次读取一快的形式来进行的,一般是一次读取512个字节,采用这种技术的Flash比较廉价。用户 不能直接运行NAND Flash上的代码,所以好多使用NAND Flash的开发板除了使用NAND Flah之外,还做上了一块小的NOR Flash来运行启动代码。 

通常小容量的用NOR Flash,由于其读取速度快,多用来存储操做系统等重要信息,而大容量的用NAND FLASH,最多见的NAND FLASH应用是嵌入式系统采用的DOC(Disk On Chip)和咱们一般用的“闪盘”,能够在线擦除。目前市面上的FLASH 主要来自Intel,AMD,Fujitsu和Toshiba,而生产NAND Flash的主要厂家有Samsung和Toshiba。

NOR Flash  和 NAND Flash 比较 

 

NOR Flash  生产厂商有 Intel和ST, Nand Flash厂商有Hynix,micon,Samsung,Toshiba 和Fujitsu等。 

2006年NAND 将占据59%的闪存市场份额,NOR的市场份额将降低到41%。而到2009 年时,NAND 的市场份额将上升到65%,NOR的市场份额将进一步下滑到35%。 

Nand主要应用:Compacflash,Secure Digi-tal,Smartmedia,SD,MMC,Xd,PC Card,USB Sticks等。 

NOR的传输效率很高,在小容量时具备很高的成本效益,更加安全,不容易出现数据故障,所以,主要应用以代码存储为主,多与运算相关。  

目前,NAND 闪存主要用在数码相机闪存卡和 MP3 播放机中,这两个市场的增加很是迅速。而 NOR 芯片主要用在手机和机顶盒中,这两个市场的增加速度相对较慢。 

 

性能比较 

 

   Flash闪存是非易失存储器,能够对称为块的存储器单元块进行擦写和再编程。任何flash器件的写入操做只能在空或已擦除的单元内进行,因此大多数状况下,在进行写入操做以前必须先执行擦除。NAND 器件执行擦除操做是十分简单的,而NOR则要求在进行擦除前先要将目标块内全部的位都写为0。 

因为擦除NOR器件时是以64~128KB 的块进行的,执行一个写入/擦除操做的时间为5s,与此相反,擦除NAND器件是以8~32KB的块进行的,执行相同的操做最多只须要4ms。 

执行擦除时块尺寸的不一样进一步拉大了 NOR 和 NADN 之间的性能差距,统计代表,对于给定的一套写入操做(尤为是更新小文件时更多的擦除操做必须在基于NOR的单元中进行。这样,当选择存储解决方案时,设计师必须权衡如下的各项因素。 

 

  ● NOR的读速度比NAND稍快一些。 

 

  ● NAND的写入速度比NOR快不少。 

 

  ● NAND的4ms擦除速度远比NOR的5s快。 

 

  ● 大多数写入操做须要先进行擦除操做。 

 

  ● NAND的擦除单元更小,相应的擦除电路更少。 

 

接口差异 

 

NOR flash带有SRAM接口,有足够的地址引脚来寻址,能够很容易地存取其内部的每个字节。 

NAND器件使用复杂的I/O口来串行地存取数据,各个产品或厂商的方法可能各不相同。8个引脚用来传送控制、地址和数据信息。 

NAND 读和写操做采用 512 字节的块,这一点有点像硬盘管理此类操做,很天然地,基于 NAND 的存储器就能够取代硬盘或其余块设备。 

 

容量和成本 

 

NAND flash 的单元尺寸几乎是 NOR 器件的一半,因为生产过程更为简单,NAND 结构能够在给定的模具尺寸内提供更高的容量,也就相应地下降了价格。

NOR flash占据了容量为1~16MB闪存市场的大部分,而NAND flash只是用在8~128MB的产品当中,这也说明NOR主要应用在代码存储介质中,NAND适合于数据存储,NAND 在CompactFlash、Secure Digital、PC Cards和MMC 存储卡市场上所占份额最大。 

可靠性和耐用性 

 

采用flahs 介质时一个须要重点考虑的问题是可靠性。对于须要扩展MTBF的系统来讲,Flash 是很是合适的存储方案。

能够从寿命(耐用性)、位交换和坏块处理三个方面来比较NOR和NAND的可靠性。 

 

   寿命(耐用性) 

  在NAND 闪存中每一个块的最大擦写次数是一百万次,而NOR的擦写次数是十万次。NAND存储器除了具备10比1的块擦除周期优点,典型的NAND块尺寸要比NOR器件小8倍,每一个NAND存储器块在给定的时间内的删除次数要少一些。  

 

   位交换 

 

  全部flash 器件都受位交换现象的困扰。在某些状况下(不多见,NAND发生的次数要比NOR多),一个比特位会发生反转或被报告反转了。 

一位的变化可能不很明显,可是若是发生在一个关键文件上,这个小小的故障可能致使系统停机。若是只是报告有问题,多读几回就可能解决了。 

固然,若是这个位真的改变了,就必须采用错误探测/错误更正(EDC/ECC)算法。位反转的问题更多见于NAND闪存,NAND的供应商建议使用NAND闪存的时候,同时使用EDC/ECC算法。

这个问题对于用 NAND 存储多媒体信息时倒不是致命的。固然,若是用本地存储设备来存储操做系统、配置文件或其余敏感信息时,必须使用EDC/ECC系统以确保可靠性。 

 

    坏块处理 

 

NAND器件中的坏块是随机分布的。之前也曾有过消除坏块的努力,但发现成品率过低,代价过高,根本不划算。 

NAND 器件须要对介质进行初始化扫描以发现坏块,并将坏块标记为不可用。在已制成的器件中,若是经过可靠的方

法不能进行这项处理,将致使高故障率。  

 

 

易于使用 

 

能够很是直接地使用基于NOR的闪存,能够像其余存储器那样链接,并能够在上面直接运行代码。 

因为须要I/O接口,NAND要复杂得多。各类NAND器件的存取方法因厂家而异。 

在使用NAND器件时,必须先写入驱动程序,才能继续执行其余操做。向NAND 器件写入信息须要至关的技巧,由于

设计师毫不能向坏块写入,这就意味着在NAND器件上自始至终都必须进行虚拟映射。 

 

软件支持 

 

当讨论软件支持的时候,应该区别基本的读/写/擦操做和高一级的用于磁盘仿真和闪存管理算法的软件,包括性能优化。  

在NOR器件上运行代码不须要任何的软件支持,在NAND器件上进行一样操做时,一般须要驱动程序,也就是内存技术驱动程序(MTD),NAND和NOR器件在进行写入和擦除操做时都须要MTD。 

 使用 NOR 器件时所须要的 MTD 要相对少一些,许多厂商都提供用于 NOR 器件的更高级软件,这其中包括 M-System的TrueFFS驱动,该驱动被Wind River System、Microsoft、QNX Software System、Symbian和Intel等厂商所采用。驱动还用于对DiskOnChip产品进行仿真和NAND闪存的管理,包括纠错、坏块处理和损耗平衡。 

ROM和硬盘的区别(电脑硬盘不是ROM,BIOS存在ROM当中):

只读内存(Read-Only Memory)就是ROM,它是一块单独的内部存储器,和随机内存RAM(即平时说的内存)类似,可是只能读取,用来存储和保存永久数据的。ROM数据不能随意更新,可是在任什么时候候均可以读取。即便是断电,ROM也可以保留数据。 

往ROM中注入数据须要另外的编译器,PC上面是没有这个功能的。通常在ROM出厂前注入信息,没有特殊状况通常不会更改内容,也就是说一般是一生都是一样的内容。 

在PC中容易误解的一点就是常常有人把ROM和HardDisk(硬盘)搞混淆,HardDisk是属于外部存储器,而ROM是内部存储器。样貌 也有很大差异,硬盘是一个立方体状的东西,而ROM更像一个扁平固定长条状的东西。硬盘能够轻易地改写内容,可是ROM不能够。并且硬盘的容量比ROM大 得多。 

在PC中ROM内的内容有BIOS程序和机器码和出厂信息之类的东西。 

而计算机的外部存储器中采用了相似磁带的装置的东东就叫磁盘。软盘、硬盘、U盘等都是磁盘的一种。

相关文章
相关标签/搜索