消息队列
2021/6/30 23:51:16
本文主要是介绍消息队列,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
消息队列发送数据时,会分成一个一个独立的数据单元,也就是消息体,每个消息体都是固定大小的存储块,在字节流上不连续。
//类型 mtype 和正文 mtext 没有强制规定,只要消息的发送方和接收方约定好即可。 struct msg_buffer { long mtype; char mtext[1024]; }; #include <stdio.h> #include <stdlib.h> #include <sys/msg.h> int main() { int messagequeueid; key_t key; // 指定一个文件,ftok 会根据这个文件的 inode,生成一个近乎唯一的 key。 // 只要文件不删除,再调用 ftok,会得到同样的 key。 if((key = ftok("/home/cindy/test", 1024)) < 0) { perror("ftok error"); exit(1); } printf("Message Queue key: %d.\n", key); // 创建一个消息队列,参数 key 是消息队列的唯一标识 if ((messagequeueid = msgget(key, IPC_CREAT|0777)) == -1) { perror("msgget error"); exit(1); } printf("Message queue id: %d.\n", messagequeueid); } # ./a.out Message Queue key: 92536. Message queue id: 32768.
System V IPC 体系有一个统一的命令行工具:ipcmk,ipcs 和 ipcrm 用于创建、查看和删除 IPC 对象。
# ipcs -q ------ Message Queues -------- key msqid owner perms used-bytes messages 0x00016978 32768 root 777 0 0
这篇关于消息队列的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-10-27[开源] 一款轻量级的kafka可视化管理平台
- 2024-10-23Kafka消息丢失资料详解:初学者必看教程
- 2024-10-23Kafka资料新手入门指南
- 2024-10-23Kafka解耦入门:新手必读教程
- 2024-10-23Kafka入门:新手必读的简单教程
- 2024-10-23Kafka入门:新手必读的简单教程
- 2024-10-23Kafka消息丢失入门:新手必读指南
- 2024-10-23Kafka消息队列入门:新手必看的简单教程
- 2024-10-23Kafka消息队列入门与应用
- 2024-10-23Kafka重复消费入门:轻松掌握Kafka重复消息处理技巧