队列演示1.

#ifndef    __03QUEUE_H__
#define    __03QUEUE_H__
//分配动态存储区的函数
void queue_init();
//释放动态存储区的函数
void queue_deinit();
//判断队列是否满的函数
int queue_full();
//判断队列是否空的函数
int queue_empty();
//统计队列中数字个数的函数
int queue_size();
//向队列中放数字的函数
void queue_push(int );
//从队列中获得数字的函数(删除数字)
int queue_pop();
//从队列中获得下一个数字的函数(不删除数字)
int queue_front();

#endif   //__03QUEUE_H__



#include "03queue.h"
static int queue[QUEUE_SIZE];
int size/*有效数字个数*/, head/*下一个要获取数字所在的位置*/, tail/*下一个放置数字的位置*/;
//分配动态存储区的函数
void queue_init() {
}
//释放动态存储区的函数
void queue_deinit() {
}
//判断队列是否满的函数
int queue_full() {
    return size == QUEUE_SIZE;
}
//判断队列是否空的函数
int queue_empty() {
return !size;
}
//统计队列中数字个数的函数
int queue_size() {
return size;
}
//向队列中放数字的函数
void queue_push(int num) {
if (size < QUEUE_SIZE) {
queue[tail] = num;
tail++;
tail %= QUEUE_SIZE;
size++;
}
}
//从队列中获得数字的函数(删除数字)
int queue_pop() {
if (size > 0) {
int ret = queue[head];
head++;
head %= QUEUE_SIZE;
size--;
return ret;
}
return -1;
}
//从队列中获得下一个数字的函数(不删除数字)
int queue_front() {
    if (size > 0) {
return queue[head];
}
return -1;
}




/*
   队列测试
   */
#include <stdio.h>
#include "03queue.h"
int main() {
int num = 0;
queue_init();
    for (num = 1;num <= 6;num++) {
queue_push(num);
}
printf("%d ", queue_pop());
printf("%d ", queue_pop());
printf("%d ", queue_pop());
queue_push(7);
queue_push(8);
printf("%d ", queue_pop());
printf("%d ", queue_pop());
printf("%d ", queue_pop());
printf("%d ", queue_pop());
printf("\n");
printf("有%d个数字\n", queue_size());
queue_deinit();
return 0;
}
















  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Redis提供了多种方式来实现消息队列。其中一种方式是使用Redis Stream。Redis Stream主要用于消息队列,可以实现消息的发布和订阅功能。与Redis的发布订阅功能相比,Redis Stream具有消息持久化的特点,即使在网络断开或Redis宕机的情况下,消息也不会丢失。\[1\] 对于中小型项目来说,Redis的Stream结构已经足够满足需求。但对于大型项目,可以考虑使用专门的消息队列系统,如RocketMQ、RabbitMQ、Kafka等。这些消息队列系统具有更强大的功能和更高的性能。\[2\] 如果没有安装专门的消息队列系统,也可以直接使用Redis提供的消息队列方案。Redis的List数据结构可以用来实现简单的消息队列。通过将消息添加到List的尾部,消费者可以从List的头部获取消息,实现消息的发布和订阅。这种方式可以降低部署和学习成本。\[3\] #### 引用[.reference_title] - *1* [redis实现消息队列的几种方式及其优劣](https://blog.csdn.net/le_17_4_6/article/details/124457648)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [《Redis实战篇》七、Redis消息队列](https://blog.csdn.net/LXYDSF/article/details/129019465)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值