搜索
bottom↓
回复: 6

求助,初学fifo,原理都懂了,看不懂程序

[复制链接]

出0入0汤圆

发表于 2014-4-8 22:39:41 | 显示全部楼层 |阅读模式
初学fifo,原理大体明白了,但是看很多相关程序,还是看不透彻,请问目前该怎么做

阿莫论坛20周年了!感谢大家的支持与爱护!!

曾经有一段真挚的爱情摆在我的面前,我没有珍惜,现在想起来,还好我没有珍惜……

出0入0汤圆

发表于 2014-4-9 07:04:16 来自手机 | 显示全部楼层
看数据结构 这本书

出0入0汤圆

 楼主| 发表于 2014-4-9 22:02:39 | 显示全部楼层
gongxd 发表于 2014-4-9 07:04
看数据结构 这本书

是谁写的啊?

出0入0汤圆

发表于 2014-4-9 22:08:22 | 显示全部楼层
fifo = first in first out,只是一个缓冲区(可以是fifo芯片,也可以是ram中开辟的一段buffer),其读取规律是先存入,先取出。just so so

出0入0汤圆

发表于 2014-4-10 08:32:38 | 显示全部楼层
严蔚敏的,考研那会用的是 大话数据结构 ,觉得讲的比严蔚敏的好太多了,不过也有很多人喷。

出0入0汤圆

发表于 2014-4-10 09:34:05 | 显示全部楼层
我简单的程序都这么用应该很好理解。有BUG的,我程序简单当然是不会出问题的
typedef struct
{
  unsigned char cBuff[MaxSize];
  unsigned char in,out,count;
}queue1;


void InitQueue(queue1 *pQ)
{
    pQ->in  = 0;
    pQ->out = 0;
    pQ->count = 0;
}

unsigned char InQueue1(queue1 *pQ,unsigned char cInData)
{
  GIE = 0;/* disable interrupts */
  if (pQ->count == MaxSize)
  {
    GIE = 1;/* enable interrupts */
    return 0;
  }
  pQ->cBuff[pQ->in++] = cInData;
  pQ->in %= MaxSize;
  pQ->count++;
  GIE = 1;/* enable interrupts */
  return 1;
}

unsigned char OutQueue1(queue1 *pQ)
{
  unsigned char ret;
  GIE = 0;/* disable interrupts */  
  if (pQ->count==0)
  {
    GIE = 1;/* enable interrupts */         
    return(0xff);     
  }
  pQ->count--;
  ret = pQ->cBuff[pQ->out];
  pQ->out++;
  pQ->out %= MaxSize;
  GIE = 1;/* enable interrupts */         
  return(ret);
}
当然我也没有其他的用法,我的都是小项目

出0入0汤圆

发表于 2014-4-10 09:50:03 | 显示全部楼层
上面吃下面拉~~~~~~~~~~
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片。注意:要连续压缩2次才能满足要求!!】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-8-27 01:20

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

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