使用bsd的queue.h实现简单队列
来源:互联网 发布:github 怎么浏览源码 编辑:程序博客网 时间:2024/06/05 08:26
队列是c中经常需要使用的数据结构,写一个0bug的队列header对于将来的代码复用很有用。
我选择使用bsd实现的队列结构,一是因为它实现简单,一个头文件里全是宏定义,二是因为它是BSD协议,代码可以随便用。
在linux下,在<sys/queue.h>里定义了五个数据结构,分别是simple linked list, list, simple queue, tail queue和circuled queue
这里介绍使用simple queue,因为simple可以支持在队头队尾分别进行插入和删除,足够简单,基本足够我日常使用。(我基本上用无优先级的队列)
下面这段代码定义task_t的队列,分别赋值0, 1, 2, 3, 4。然后删除3,最后循环打印这个队列
我选择使用bsd实现的队列结构,一是因为它实现简单,一个头文件里全是宏定义,二是因为它是BSD协议,代码可以随便用。
在linux下,在<sys/queue.h>里定义了五个数据结构,分别是simple linked list, list, simple queue, tail queue和circuled queue
这里介绍使用simple queue,因为simple可以支持在队头队尾分别进行插入和删除,足够简单,基本足够我日常使用。(我基本上用无优先级的队列)
下面这段代码定义task_t的队列,分别赋值0, 1, 2, 3, 4。然后删除3,最后循环打印这个队列
- 我不喜欢把变量声明和定义写一起,分开比较好。
- queue.h里面大多是使用指针的宏,所以在写宏的时候注意传指针就不容易错。
- SIMPLEQ_ENTRY(task_t)定义了每个元素与其它前后元素相联系的结构体,可以通过它找到前后元素,至于这个结构体叫什么名字,都无所谓。(所以是否可以把这个结构体写进宏里更能精简代码呢?我觉得完全是可以的)
- 如果queue.h可以有pop的宏就好了,查询节点再删除这样的操作显得很麻烦
阅读全文
0 0
- 使用bsd的queue.h实现简单队列
- 使用Java实现简单的队列(queue)
- Java实现一个简单的队列---Queue
- java.util.Queue(队列)的简单使用
- 队列的实现 queue
- queue队列的实现
- 使用linux中标准的queue.h头文件插件链表,队列,循环队列
- 小佳弱弱学习——queue队列的简单实现
- 算法导论-------------队列(queue)的简单实现
- 简单模拟实现队列Queue的模板类
- queue.h之tailq.h尾队列理解使用
- 消息队列(Message Queue)的简单使用
- (C#)使用队列(Queue)解决简单的并发问题
- 使用队列(Queue)解决简单的并发问题
- 队列数据结构 Queue.h
- 队列,Queue.h
- tail queue in queue.h for free bsd.
- C++实现的队列queue
- 刷新一下字节度量...(1BB)
- 阿里编码规约怎么使用?
- PMD安装和使用
- POJO与JavaBean的区别
- 正则表达式 regexp
- 使用bsd的queue.h实现简单队列
- java架构师之路:JAVA程序员必看的15本书的电子版下载地址
- Android Studio 快捷键 for Mac OS X
- HTTP2.0原理详细解析
- mysql 设置远程连接访问
- linux系统函数container_of浅析
- 51nod 1875 丢手绢 vector模拟循环问题
- 五 Java修饰符
- 迭代器Iterator与语法糖for-each