找回密码
 注册
关于网站域名变更的通知
查看: 320|回复: 1
打印 上一主题 下一主题

flash 和 eeprom 区别和关系

[复制链接]
  • TA的每日心情
    开心
    2019-11-20 15:00
  • 签到天数: 2 天

    [LV.1]初来乍到

    跳转到指定楼层
    1#
    发表于 2018-11-14 13:20 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

    EDA365欢迎您登录!

    您需要 登录 才可以下载或查看,没有帐号?注册

    x
    flash 和 eeprom 区别和关系& |  w2 m, G% Q5 J- v
    单片机运行时的数据都存在于RAM(随机存储器)中,在掉电后RAM 中的数据是无
      U$ Z2 {9 {2 |
    ' L. R- D1 x$ _/ e0 z法保留的,那么怎样使数据在掉电后不丢失呢?这就需要使用EEPROM 或FLASHROM 等9 _, f* U% z1 x) ~) e' R2 ^1 L

    & X/ u; Y  L. u* F9 N7 m存储器来实现。在传统的单片机系统中,一般是在片外扩展存储器,单片机与存储器之间通3 ]# C2 g# t: C+ Y  g+ N' T

    , _- u, ~$ S  j& `过IIC 或SPI 等接口来进行数据通信。这样不光会增加开发成本,同时在程序开发上也要花0 K9 f$ d, U7 Z8 V
    * K8 m3 t6 |! ~
    更多的心思。在STC 单片机中内置了EEPROM(其实是采用IAP 技术读写内部FLASH 来$ M/ k  q# s  Z- B( g/ o) s
    $ v3 d; E$ e# f5 d
    实现EEPROM),这样就节省了片外资源,使用起来也更加方便。下面就详细介绍STC 单! v) T  W, H# v& l! ], N5 N6 B
    1 m' l2 q+ E- H# Q
    片机内置EEPROM 及其使用方法。/ S8 h' B* ~) j0 ^. F
    7 Q' `- D& Z* y; ]+ Z9 o9 p
    flash是用来放程序的,可以称之为程序存储器,可以擦出写入但是基本都是整个扇区进行的.# ~# |- c; ]3 j. h" Q$ D1 v
    / Y+ }# T- k; y5 P& z
    一般来说 单片机里的flash都用于存放运行代码,在运行过程中不能改;
    / P% P$ |3 P  m% E
    . A' R" c" k* {' ^. i9 p( `EEPROM是用来保存用户数据,运行过程中可以改变,比如一个时钟的闹铃时间初始化设定为12:00,后来在运行中改为6:00,这是保存在EEPROM里,不怕掉电,就算重新上电也不需要重新调整到6:00
    + M& e# P8 V0 D9 L5 g  h& y* N+ |0 n2 i
    下面是网上详细的说法,感觉不错:
    ( E/ W: y. ^; }+ o8 s! ~9 h4 c+ q
    FLASH 和EEPROM的最大区别是FLASH按扇区操作,EEPROM则按字节操作,二者寻址方法不同,存储单元的结构也不同,FLASH的电路结构较简单,同样容量占芯片面积较小,成本自然比EEPROM低,因而适合用作程序存储器,EEPROM则更多的用作非易失的数据存储器。当然用FLASH做数据存储器也行,但操作比EEPROM麻烦的多,所以更“人性化”的mcu设计会集成FLASH和EEPROM两种非易失性存储器,而廉价型设计往往只有 FLASH,早期可电擦写型MCU则都是EEPRM结构,现在已基本上停产了。2 O$ Z. }' \2 R# H; Z+ M2 N4 _+ d+ \

    / a' R% ^3 t- Y: _7 ^在芯片的内电路中,FLASH和EEPROM不仅电路不同,地址空间也不同,操作方法和指令自然也不同,不论冯诺伊曼结构还是哈佛结构都是这样。技术上,程序存储器和非易失数据存储器都可以只用FALSH结构或EEPROM结构,甚至可以用“变通”的技术手段在程序存储区模拟“数据存储区”,但就算如此,概念上二者依然不同,这是基本常识问题。
    0 z0 L. [! }0 X2 M/ p
    ) L& J3 S$ k# g: o' _# j- q# t: [EEPROM:电可擦除可编程只读存储器,Flash的操作特性完全符合EEPROM的定义,属EEPROM无疑,首款Flash推出时其数据手册上也清楚的标明是EEPROM,现在的多数Flash手册上也是这么标明的,二者的关系是“白马”和“马”。至于为什么业界要区分二者,主要的原因是 Flash EEPROM的操作方法和传统EEPROM截然不同,次要的原因是为了语言的简练,非正式文件和口语中Flash EEPROM就简称为Flash,这里要强调的是白马的“白”属性而非其“马”属性以区别Flash和传统EEPROM。
      B. [1 \/ S0 w" D" s2 o. `2 H( W6 C- R# l& v: t. i
    Flash的特点是结构简单,同样工艺和同样晶元面积下可以得到更高容量且大数据量+ J& q: i/ l% m) E, y

    . L6 O- w+ r, w下的操作速度更快,但缺点是操作过程麻烦,特别是在小数据量反复重写时,所以在MCU中Flash结构适于不需频繁改写的程序存储器。
    7 P/ D& C6 k. w) {7 M: X+ q
    * b" g$ ~6 K% H4 y很多应用中,需要频繁的改写某些小量数据且需掉电非易失,传统结构的EEPROM在此非常适合,所以很多MCU内部设计了两种EEPROM结构,FLASH的和传统的以期获得成本和功能的均衡,这极大的方便了使用者。随着ISP、IAP的流行,特别是在程序存储地址空间和数据存储地址空间重叠的MCU系中,现在越来越多的MCU生产商用支持IAP的程序存储器来模拟EEPROM对应的数据存储器,这是低成本下实现非易失数据存储器的一种变通方法。为在商业宣传上取得和双EEPROM工艺的“等效”性,不少采用Flash程序存储器“模拟”(注意,技术概念上并非真正的模拟)EEPROM数据存储器的厂家纷纷宣称其产品是带EEPROM的,严格说,这是非常不严谨的,但商人有商人的目的和方法,用Flash“模拟”EEPROM可以获取更大商业利益,所以在事实上,技术概念混淆的始作俑者正是他们。$ N9 O+ ~! c: x% U5 s1 I2 X
    7 S' u$ e" ~8 y
    从成本上讲,用Flash“模拟”EEPROM是合算的,反之不会有人干,用EEPROM模拟Flash是怎么回事呢?这可能出在某些程序存储空间和数据存储空间连续的MCU上。这类MCU中特别是存储容量不大的低端MCU依然采用EEPROM作为非易失存储器,这在成本上反而比采用Flash和传统EEPROM双工艺的设计更低,但这种现象仅仅限于小容量前提下。因Flash工艺的流行,现在很多商人和不够严谨的技术人员将程序存储器称为Flash,对于那些仅采用传统EEPROM工艺的MCU而言,他们不求甚解,故而错误的将EEPROM程序存储器称为“ 模拟Flash”,根本的原因是他们未理解Flash只是一种存储器结构而非存储器的用途,错误的前提自然导致错误的结论。商业上讲,用EEPROM模拟 Flash是不会有人真去做的愚蠢行为,这违背商业追求最大利益的原则,技术上也不可行,而对于技术人员而言。本质的问题是Flash是一种存储器类型而非MCU中的程序存储器,即使MCU的程序存储器用的是Flash,但其逆命题不成立
    1 Y" X# k0 H4 ?
    您需要登录后才可以回帖 登录 | 注册

    本版积分规则

    关闭

    推荐内容上一条 /1 下一条

    EDA365公众号

    关于我们|手机版|EDA365电子论坛网 ( 粤ICP备18020198号-1 )

    GMT+8, 2025-7-23 09:22 , Processed in 0.109375 second(s), 23 queries , Gzip On.

    深圳市墨知创新科技有限公司

    地址:深圳市南山区科技生态园2栋A座805 电话:19926409050

    快速回复 返回顶部 返回列表