c语言尾队列tailq使用示例分享

 更新时间:2014年01月28日 11:48:47   作者:  
这篇文章主要介绍了c语言尾队列tailq使用示例,大家参考使用吧

queue和list的结构定义和操作都在'sys/queue.h'中完成, 主要定义了下面四种数据结构:

1单向列表(single-linked lists)
2单向尾队列(single-linked tail queue)
3列表(lists)
4尾队列(tail queues)



使用示例

复制代码 代码如下:

#include <stdio.h>
#include <stdlib.h>
#include <sys/queue.h>

/*
  定义一个结构体,它只是尾队列的一个元素
  它必须包含一个TAILQ_ENTRY来指向上一个和下一个元素
*/
struct tailq_entry {
 int value;

 TAILQ_ENTRY(tailq_entry) entries;
};

//定义队列的头部
TAILQ_HEAD(, tailq_entry) my_tailq_head;

int main(int argc, char  *argv[])
{
 //定义一个结构体指针
 struct tailq_entry *item;
 //定义另外一个指针
 struct tailq_entry *tmp_item;

 //初始化队列
 TAILQ_INIT(&my_tailq_head);

 int i;
 //在队列里添加10个元素
 for(i=0; i<10; i++) {
  //申请内存空间
  item = malloc(sizeof(*item));
  if (item == NULL) {
   perror("malloc failed");
   exit(-1);
  }
  //设置值
  item->value = i;

  /*
     将元素加到队列尾部
     参数1:指向队列头的指针
     参数2:要添加的元素
     参数3:结构体的变量名
  */
  TAILQ_INSERT_TAIL(&my_tailq_head, item, entries);
 }

 //遍历队列
 printf("Forward traversal: ");
 TAILQ_FOREACH(item, &my_tailq_head, entries) {
  printf("%d ",item->value);
 }
 printf("\n");

 //添加一个新的元素
 printf("Adding new item after 5: ");
 TAILQ_FOREACH(item, &my_tailq_head, entries) {
  if (item->value == 5) {
   struct tailq_entry *new_item = malloc(sizeof(*new_item));
   if (new_item == NULL) {
    perror("malloc failed");
    exit(EXIT_FAILURE);
   }
   new_item->value = 10;
   //插入一个元素
   TAILQ_INSERT_AFTER(&my_tailq_head, item, new_item, entries);
   break;
  }
 }
 TAILQ_FOREACH(item, &my_tailq_head, entries) {
  printf("%d ", item->value);
 }
 printf("\n");

 //删除一个元素
 printf("Deleting item with value 3: ");
 for(item = TAILQ_FIRST(&my_tailq_head); item != NULL; item = tmp_item) {
  if (item->value == 3) {
   //删除一个元素
   TAILQ_REMOVE(&my_tailq_head, item, entries);
   //释放不需要的内存单元
   free(item);
   break;
  }
  tmp_item = TAILQ_NEXT(item, entries);
 }

 TAILQ_FOREACH(item, &my_tailq_head, entries) {
  printf("%d ", item->value);
 }
 printf("\n");

 //清空队列
 while (item = TAILQ_FIRST(&my_tailq_head)) {
  TAILQ_REMOVE(&my_tailq_head, item, entries);
  free(item);
 }

 //查看是否为空
 if (!TAILQ_EMPTY(&my_tailq_head)) {
  printf("tail queue is  NOT empty!\n");
 }

 return 0;

}

相关文章

  • C++内存池两种方案解析

    C++内存池两种方案解析

    这篇文章主要详情介绍了C++内存池两种方案做对比,对此感兴趣的小伙伴一起来看看吧
    2021-08-08
  • C++ Opengl图形颜色功能附源码下载

    C++ Opengl图形颜色功能附源码下载

    这篇文章主要介绍了C++ Opengl图形颜色功能附源码下载,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-11-11
  • C++实现扫雷、排雷小游戏

    C++实现扫雷、排雷小游戏

    这篇文章主要为大家详细介绍了C++实现扫雷、排雷小游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-05-05
  • C语言的变量与常量 字符字符串与转义字符详解

    C语言的变量与常量 字符字符串与转义字符详解

    这篇文章主要介绍了详解C语言的变量与常量 字符字符串与转义字符,包括其之间的区别是C语言入门学习中的基础知识,需要的朋友可以参考下
    2021-10-10
  • C语言直接选择排序算法详解

    C语言直接选择排序算法详解

    直接选择排序就是遍历整个数组,每遍历一遍的目的是找出该数组中的最大数和最小数对应的下标,然后将最小数和数组的第一个数进行交换,最大数和数组的最后一个数进行交换,然后缩小范围再次遍历
    2022-08-08
  • 详解C++中函数模板的定义与使用

    详解C++中函数模板的定义与使用

    函数模板实质就是参数化数据类型,称这种编程模式为数据类型泛化编程。本文将通过示例来和大家一起了解下C++中函数模板的定义与使用,需要的可以参考一下
    2022-09-09
  • C++数据序列化方式(自定义结构体的保存和读取)

    C++数据序列化方式(自定义结构体的保存和读取)

    这篇文章主要介绍了C++数据序列化方式(自定义结构体的保存和读取),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-08-08
  • C++深入讲解哈夫曼树

    C++深入讲解哈夫曼树

    给定N个权值作为N个叶子结点,构造一棵二叉树,若该树的带权路径长度达到最小,称这样的二叉树为最优二叉树,也称为哈夫曼树(Huffman Tree)。哈夫曼树是带权路径长度最短的树,权值较大的结点离根较近
    2022-05-05
  • 详解CLion配置openMP的方法

    详解CLion配置openMP的方法

    这篇文章主要介绍了CLion配置openMP的方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-02-02
  • C语言摄氏度互相转换华氏

    C语言摄氏度互相转换华氏

    这篇文章主要介绍了C语言摄氏度互相转换华氏,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-01-01

最新评论