大并发数据队列

发布时间:2020-07-02 15:23:17 作者:佛观一杯水
来源:网络 阅读:812

图解大并发数据队列

#include<stdio.h>

#include<stdlib.h>

#include<memory.h>

#define N 100

#define mytype int

struct MyQueue

{

  mytype data[N];//数组存储队列

  int front;//拉屎

  int rear;//吃东西

};


typedef struct MyQueue myQ;

//初始化

void init(myQ *p)

{

  p->front = p->rear = 0;

  memset(p->data,0,sizeof(mytype)*N);


}

void print(myQ *p)

{


  if(isempty(p)==1)

  {

      return 0;

  }else{

      int i;

      for(i=p->front;i<p->rear;i++)

      {

          printf("%d",p->data[i]);

      }

  }

}

int isfull(myQ *p)

{

   if(p->rear == N)

   {

     return 1;

   }else

   {

     return 0;

   }

}

int isempty(myQ *p)

{

   if(p->front==p->rear)

   {

       return 1;

   }else{

       return 0;

   }

}

void enQ(myQ *p,mytype insertdata)

{

   if(isfull(p)==1)

   {

       return;

   }else{

       p->data[p->rear] = insertdata;

       p->rear+=1;

   }

}

mytype deQ(myQ *p)

{

   if(isempty(p)==1)

   {

       return 0;

   }

   int index = (p->rear)-(p->front);

   if(index==1)

   {

        return p->data[0];

   }else{

       int i;

      // printf("\n index=%d",index);

       for(i=0;i<index-1;i++)

       {

           p->data[i] = p->data[i+1];

       }

       --p->rear;


   }

    //printf("\n index=%d",p->rear);

   return p->data[p->rear];

}

mytype array_shift(myQ *p)

{

   if(isempty(p)==1)

   {


         exit(1);

   }

   else{

        int num = p->front;


       free(p->data[num]);

       return p->data[p->front++];

   }


}

mytype array_pop(myQ *p)

{

    if(isempty(p)==1)

    {


        return 0;

    }else{


       int num = p->rear;

       free(p->data[num]);

       return p->data[--p->rear];

    }



}


void main()

{


    myQ my1;//创建结构体

    init(&my1);

    enQ(&my1,1);

    enQ(&my1,2);

    enQ(&my1,3);

    enQ(&my1,4);



    printf("\npop =%d",array_pop(&my1));

    printf("\nnumber=%d",array_shift(&my1));

    printf("\n one=%d",array_shift(&my1));

    printf("\n two = %d",array_shift(&my1));


    printf("\n three = %d",array_shift(&my1));


    system("pause");

}









推荐阅读:
  1. Nginx大并发优化实战
  2. 海量账户大并发实时查询解决方案

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

列队 并发数据

上一篇:如何在linux系统中下载文件

下一篇:Python画树的方法

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》