单片机运行时的数据都存在于RAM(随机存储器)中,在掉电后RAM 中的数据是无法保留的,那么怎样使数据在掉电后不丢失呢?这就需要使用EEPROM 或FLASHROM 等存储器来实现。在传统的单片机系统中,一般是在片外扩展存储器,单片机与存储器之间通过IIC 或SPI 等接口来进行数据通信。这样不光会增加开发成本,同时在程序开发上也要花更多的心思。在STC 单片机中内置了EEPROM(其实是采用IAP 技术读写内部FLASH 来实现EEPROM),这样就节省了片外资源,使用起来也更加方便。下面就详细介绍STC 单片机内置EEPROM 及其使用方法。

flash是用来放程序的,可以称之为程序存储器,可以擦出写入但是基本都是整个扇区进行的。一般来说,单片机里的flash都用于存放运行代码,在运行过程中不能改。

EEPROM是用来保存用户数据,运行过程中可以改变,比如一个时钟的闹铃时间初始化设定为12:00,后来在运行中改为6:00,这是保存在EEPROM里,不怕掉电,就算重新上电也不需要重新调整到6:00。

下面是网上详细的说法,感觉不错:

FLASH 和EEPROM的最大区别是FLASH按扇区操作,EEPROM则按字节操作,二者寻址方法不同,存储单元的结构也不同,FLASH的电路结构较简单,同样容量占芯片面积较小,成本自然比EEPROM低,因而适合用作程序存储器,EEPROM则更多的用作非易失的数据存储器。当然用FLASH做数据存储器也行,但操作比EEPROM麻烦的多,所以更“人性化”的MCU设计会集成FLASH和EEPROM两种非易失性存储器,而廉价型设计往往只有 FLASH,早期可电擦写型MCU则都是EEPRM结构,现在已基本上停产了。 在芯片的内电路中,FLASH和EEPROM不仅电路不同,地址空间也不同,操作方法和指令自然也不同,不论冯诺伊曼结构还是哈佛结构都是这样。技术上,程序存储器和非易失数据存储器都可以只用FALSH结构或EEPROM结构,甚至可以用“变通”的技术手段在程序存储区模拟“数据存储区”,但就算如此,概念上二者依然不同,这是基本常识问题。

EEPROM:电可擦除可编程只读存储器,Flash的操作特性完全符合EEPROM的定义,属EEPROM无疑,首款Flash推出时其数据手册上也清楚的标明是EEPROM,现在的多数Flash手册上也是这么标明的,二者的关系是“白马”和“马”。至于为什么业界要区分二者,主要的原因是 Flash EEPROM的操作方法和传统EEPROM截然不同,次要的原因是为了语言的简练,非正式文件和口语中Flash EEPROM就简称为Flash,这里要强调的是白马的“白”属性而非其“马”属性以区别Flash和传统EEPROM。

Flash的特点是结构简单,同样工艺和同样晶元面积下可以得到更高容量且大数据量下的操作速度更快,但缺点是操作过程麻烦,特别是在小数据量反复重写时,所以在MCU中Flash结构适于不需频繁改写的程序存储器。很多应用中,需要频繁的改写某些小量数据且需掉电非易失,传统结构的EEPROM在此非常适合,所以很多MCU内部设计了两种EEPROM结构,FLASH的和传统的以期获得成本和功能的均衡,这极大的方便了使用者。随着ISP、IAP的流行,特别是在程序存储地址空间和数据存储地址空间重叠的MCU系中,现在越来越多的MCU生产商用支持IAP的程序存储器来模拟EEPROM对应的数据存储器,这是低成本下实现非易失数据存储器的一种变通方法。为在商业宣传上取得和双EEPROM工艺的“等效”性,不少采用Flash程序存储器“模拟”(注意,技术概念上并非真正的模拟)EEPROM数据存储器的厂家纷纷宣称其产品是带EEPROM的,严格说,这是非常不严谨的,但商人有商人的目的和方法,用Flash“模拟”EEPROM可以获取更大商业利益,所以在事实上,技术概念混淆的始作俑者正是他们。从成本上讲,用Flash“模拟”EEPROM是合算的,反之不会有人干,用EEPROM模拟Flash是怎么回事呢?这可能出在某些程序存储空间和数据存储空间连续的MCU上。这类MCU中特别是存储容量不大的低端MCU依然采用EEPROM作为非易失存储器,这在成本上反而比采用Flash和传统EEPROM双工艺的设计更低,但这种现象仅仅限于小容量前提下。因Flash工艺的流行,现在很多商人和不够严谨的技术人员将程序存储器称为Flash,对于那些仅采用传统EEPROM工艺的MCU而言,他们不求甚解,故而错误的将EEPROM程序存储器称为“ 模拟Flash”,根本的原因是他们未理解Flash只是一种存储器结构而非存储器的用途,错误的前提自然导致错误的结论。商业上讲,用EEPROM模拟 Flash是不会有人真去做的愚蠢行为,这违背商业追求最大利益的原则,技术上也不可行,而对于技术人员而言。本质的问题是Flash是一种存储器类型而非MCU中的程序存储器,即使MCU的程序存储器用的是Flash,但其逆命题不成立

FLASH与E²PROM的区别相关推荐

  1. Flash和HTML5有什么区别?为什么Flash应用场景越来越少了?

    Flash和HTML5有什么区别?为什么Flash应用场景越来越少了? Flash,这个曾经使我们浏览器电脑必装的插件之一,它原本就是一款安装于浏览器的Flash插件(Adobe FlashPlaye ...

  2. RAM、ROM、FLASH的存储原理及区别

    一.RAM(Random Access Memory )随机存取存储器,主要作用是存储代码和数据供CPU 需要时调用.这些数据的存储并不像用袋子盛米那般,更像是图书馆中用有格子的书架存放书籍一样,不但 ...

  3. 【存储器了解 RAM flash和eeprom存储器的区别和作用】

    1.首先我们先了解一下 扇区(Sector),块(Block),页(page)的概念 用一个图最能说明其关系 根据容量大小来说,它们的关系: 页(Page)< 扇区(Sector) < 块 ...

  4. RAM flash和eeprom存储器的区别和作用

    之前对各种存储器一直不太清楚,今天总结一下. 存储器分为两大类:ram和rom. ram就不讲了,今天主要讨论rom. rom最初不能编程,出厂什么内容就永远什么内容,不灵活.后来出现了prom,可以 ...

  5. nand flash和nor flash的这几点区别你知道吗?

    这篇文章讲解nand flash和nor flash的特点和区别,不涉及存储原理的讲解 (一)Flash简介 FLASH是一种存储芯片,全名叫Flash EEPROM Memory,通地过程序可以修改 ...

  6. Flash,RAM,ROM区别

    本文转载自:终于有人说清楚了什么是DRAM.什么是NAND Flash 所有使用者对"存储器"这个名词可是一点都不陌生,因为所有的电子产品都必须用到存储器,且通常用到不只一种存储器 ...

  7. 解释ROM、RAM、SRAM、DRAM与FLASH在使用上的区别及其原因

    ROM(Read Only Memory):只读存储器,掉电时可以保存数据. 只读存储器,在单片机运行时,只能从中读取数据,不能向里面写数据.特点是掉电不丢失数据,在单片机中主要用来存储代码和常量等内 ...

  8. STM32中FLASH/System Memory/SRAM的区别

    转载博客园:https://www.cnblogs.com/429512065qhq/p/8305008.html Main Flash memory 是STM32内置的Flash,一般我们使用JTA ...

  9. 内存专题--各种RAM/ROM/Cache/Flash等内存概念与区别

    内存,或内存储器,又称为主存储器,是关系到计算机运行性能高低的关键部件之一,无疑是非常重要的.为了加快系统的速度,提高系统的整体性能,我们看到,计算机中配置的内存数量越来越大,而内存的种类也越来越多. ...

最新文章

  1. sqap不支持python3吗_Supporting Python 3(支持python3)——欢迎来到Python 3
  2. 简单三步-实现dede站内搜索功能
  3. Building wheel for wrapt (setup.py) ... error
  4. 《漫画算法2》源码整理-8 链表中倒数第K个节点元素
  5. 阴阳师人数最多的服务器,《阴阳师》手游部分服务器合并公告
  6. ArcGIS网络分析之Silverlight客户端最近设施点分析(四)
  7. Linux:分享50个实用的基础命令,欢迎收藏!
  8. java mail outlook_已启用Outlook API邮件与邮箱用户
  9. 【Scikit-Learn 中文文档】支持向量机 - 监督学习 - 用户指南 | ApacheCN
  10. 快照(Snapshot)
  11. iOS 三步完成购买苹果开发者账号
  12. 电气绘图软件-AutoCAD Electrical:介绍
  13. 「硬见小百科」很全的二极管干货
  14. 第七颗头骨 忘魂花 凤凰
  15. 数据挖掘人工神经网络,神经网络的数据处理
  16. 使用Selenium实现微博爬虫:预登录、展开全文、翻页
  17. 万龙链——广应用场景,强价值背书,催生无限可能
  18. ELK之ElasticsearchKibana安装/学习
  19. 第九城市CEO朱骏:一个人的掘金游戏
  20. 基于jQuery的富文本编辑器summernote插件的使用教程

热门文章

  1. springboot之websocket
  2. 【机器学习实战】第2章 k-近邻算法(kNN)
  3. Linux下OpenSSL的安装与使用
  4. 深入理解客户的需求至关重要!
  5. ocp 042 第六章:管理用户安全性
  6. asp.net ajax1.0基础回顾(五):调用ASMX(WebService)
  7. python招生海报_从原研哉的哲学中学习海报设计
  8. laravel 数据库获取值的常用方法
  9. 卸料装置弹性零件的计算方法_冲裁力、卸料力及推件力的计算-常见问题.doc
  10. mysql 记录更新 内部_MySQL 入门(1):查询和更新的内部实现