lesson 3 内存

原创 2016年08月28日 14:53:43

  程序员主要和内存打交道

  内存的物理结构

  ROM:只能读取 ,早期的手机操作系统放在ROM中

  RAM:能够读取和写入, DRAM(经常更新) SRAM(不经常更新) ,里面的数据断电即消

  

  内存中把引脚分为: 电源 、地址 (决定寻址能力、)数据 、控制   四大类


  例如一个芯片有:A0到A9 10个地址引脚 ,可以表示 1024个地址

                                  D0到D7 8个数据引脚, 能接受8个数据信号,一次可以输出或输入的数据量 ,  8bit= 1byte

当前芯片的容量是 1024×1 byte =1KB 能存储1kb的数据

往内存写数据

     首先给芯片两边分别接入5V,0V的电压,如果当前的地址是0001111000,通过它找到芯片当中指定的位置,找到指定的存储场合,然后再将我们的电流信号写入数据引脚 (比如是00001111),(1的位置接高电平)再给WR置1 指定的地址就会写入指定的值.

     所以写内存必须按照一定的格式写。


内存的逻辑结构

   把内存比如一间间存储数据的楼房,通过地址引脚,每个楼房都有楼层和门牌号。 每层都有编号,就是地址。每个楼层的大小由数据引脚来决定的。

         

         char = 1 byte   一层能放下

         int = 4    byte  把四层打包成一层,取首楼层地址(比如 0011),楼层的编号还是存在的


为什么 数组的访问数据最快

     内存地址都是从上往下累加的,累加一步步来, 数组存一个连续的数据 ,取的时候只需要拿到首地址,然后依次挨个往后取。这种架构非常符合内存的结果, 操作效率非常高,按照当前整个数据的模式来依次找,当需要访问或删除里面数据,只要取到首地址,通过首地址来进行偏移,只需要取一次数据。


为什么 要提出栈和队列

     如果要删除其中一个数据,CPU首先寻找到首地址,偏移到删除位置,删掉。然后把其他数据往前移。就会很慢。因此设计了其他数据结构。

      

栈:      用于数据记录   FILO  先进后出   入栈   出栈

队列 : 按照进去的顺序挨个拖出来

链表 : 存储了数据和指针(数据地址) ,通知指针指向找到下一个值,方便删除,只需要改指针指向的地        址。

 

版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

[lesson5_1]Flex.3样式和主题(1)part2

  • 2009年01月07日 17:20
  • 12.01MB
  • 下载

嵌入式学习-uboot-lesson7-内存初始化

6410所使用的内存为DDR 210使用的是DDR2 2440使用的是SDRAM,关于他们之间的区别,我在以前的文章中ok6410内存及启动流程简单介绍过,有兴趣的可以看看。1. 地址空间S3C641...

【Android Training - Performance】提高显示布局文件的性能[Lesson 3 - 按需载入视图(ViewStub的使用方法)]

Loading Views On Demand [按需载入视图] 某些时候,我们需要一些很复杂的视图却仅仅很少用到。如果我们在它仅仅需要的时候再载入,这样可以减少内存的使用并且给用户带来流畅的体验。 ...

郭天祥 C51单片机教程 lesson3

  • 2010年09月12日 22:44
  • 1.4MB
  • 下载

lesson3~数码管的静态显示&定时器&中断的应用

1. 显示器及其接口单片机系统中常用的显示器有:发光二极管LED(Light Emitting Diode)显示器、液晶LCD(Liquid Crystal Display)显示器、CRT显示器等。L...

BC Competency Lesson 3 Assessment .docx

  • 2012年12月03日 07:34
  • 45KB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:lesson 3 内存
举报原因:
原因补充:

(最多只允许输入30个字)