#ifndef __FIFO_H
#define __FIFO_H
#define DATESIZE 10
typedef struct node{
int date[DATESIZE];
int front;
int rear;
}FIFO,*FI;
#endif
在公司里呢肯定不会这么简单,因为这种储存结构我们定义一次肯定要多次使用,在宏观上可能会同时接收多个地方的数据,例如同时接收串口1或者串口2的数据,因此我们必须要做一个兼容性。也就是结构体里套一个结构体,假如存在三个串口
#ifndef __FIFO_H
#define __FIFO_H
#define DATESIZE 10
#define UARTNUM 3
typedef struct node{
int date[DATESIZE];
int front;
int rear;
}FIFO,*FI;
typedef struct Fifo{
FIFO FIFO_RE[UARTNUM];
}FIFO_RE_DATE;
#endif
按照该方式即可。
在我们最开始学习C语言的时候,要让一个数据在一个范围内循环赋值通常使用对总长度求余,那么循环队列也是使用该方法,让他在一定长度的数组内不停的循环,并保持先进先出的顺序。
#include
#include
#include "FIFO.h"
#include
/* run this program using the console pauser or add your own getch, system("pause") or input loop */
void Init_Fifo(FI queue)
{
queue->front = 0;
queue->rear = 0;
printf("队列初始化成功......\r\n");
printf("队列总长度为:%d\r\n",DATESIZE);
printf("队头:%d\r\n",queue->front);
printf("队尾:%d\r\n",queue->rear);
}
bool Fifo_Isnull(FI queue)
{
if(queue->front == queue->rear)
{
return true;
}else
{
return false;
}
}
bool Fifo_Isfull(FI queue)
{
if(((queue->rear + 1) % DATESIZE) == queue->front)
{
return true;
}else
{
return false;
}
}
void input_data(FI queue,int val)
{
if(Fifo_Isfull(&queue))
{
printf("队列已满,入队失败\r\n");
return;
}
queue->date[queue->rear] = val;
queue->rear = (queue->rear+1) % DATESIZE;
printf("入队成功:%d 队头:%d 队尾:%d \r\n",val,queue->front,queue->rear);
}
int out_put(FI queue)
{
int out = 0;
if(Fifo_Isnull(&queue))
{
printf("队列为空,出队失败\r\n");
return;
}
out = queue->date[queue->front];
queue->front = (queue->front+1) % DATESIZE;
printf("出队成功:%d 队头:%d 队尾:%d \r\n",out,queue->front,queue->rear);
return out;
}
void showfifo(FI queue)
{
int cur = 0;
if(Fifo_Isnull(&queue))
{
printf("队列为空,出队失败\r\n");
return;
}
cur = queue->front;
while(cur != queue->rear)
{
printf("%d ",queue->date[cur]);
cur = (cur+1) % DATESIZE;
}
printf("\r\n");
}
int main(int argc, char *argv[]) {
FIFO fifo;
Init_Fifo(&fifo);
input_data(&fifo,10);
input_data(&fifo,20);
input_data(&fifo,30);
input_data(&fifo,40);
input_data(&fifo,50);
input_data(&fifo,60);
showfifo(&fifo);
out_put(&fifo);
out_put(&fifo);
out_put(&fifo);
out_put(&fifo);
showfifo(&fifo);
return 0;
}