当前位置:  编程技术>c/c++/嵌入式

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

    来源: 互联网  发布时间:2014-10-23

    本文导语:  queue和list的结构定义和操作都在'sys/queue.h'中完成, 主要定义了下面四种数据结构: 1单向列表(single-linked lists)2单向尾队列(single-linked tail queue)3列表(lists)4尾队列(tail queues) 使用示例 代码如下:#include #include #include /*  定义一个...

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

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



使用示例

代码如下:

#include
#include
#include

/*
  定义一个结构体,它只是尾队列的一个元素
  它必须包含一个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; ivalue = 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;

}


    
 
 

您可能感兴趣的文章:

  • linux C 语言 多线程读写消息队列
  • C语言循环队列的表示与实现实例详解
  • C语言单链队列的表示与实现实例详解
  • 优先队列(priority_queue)的C语言实现代码
  • c语言实现MD5算法完整代码示例
  • 使用c语言判断100以内素数的示例(c语言求素数)
  • c语言中if 语句的作用范围示例代码
  • c语言打印输出双引号的方法示例
  • c语言动态数组示例
  • c语言strftime时间格式化示例
  • c语言文件读写示例(c语言文件操作)
  • c语言求阶乘精确值示例
  • c语言的cps实现求fibonacci数列示例
  • c语言多线程编程使用示例
  • c语言生成随机uuid编码示例
  • c语言二进制数按位输出示例
  • c语言随机数函数示例
  • c语言获取文件大小的示例
  • 一个小示例告诉你Python语言的优雅之处
  • C语言小程序 杨辉三角示例代码
  • C语言使用普通循环方法和递归求斐波那契序列示例代码
  • c语言可变参数实现示例
  • 用C语言获取文件的大小示例分享
  • c语言线程终止练习示例
  • c语言合并两个已排序数组的示例(c语言数组排序)
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • 以NetBeans IDE为例介绍如何使用XML中Schema语言
  • kliyx是使用C++语言编程的,还是用C语言编程的?
  • 在linux下使用C语言一般是使用什么编程工具呢???
  • c语言随机数函数示例 iis7站长之家
  • 如何获取客户端浏览器所使用的语言,特别是要区分简繁体!
  • 我想在linux下开发软件,但不知道使用什么语言好,和使用什么开发工具
  • 如何使用汇编语言
  • linux下用c语言写的程序,其中可以使用STL模板吗?先谢谢各位
  • c语言在unix系统下,如何获取cpu使用率
  • 如何在C语言的宏中使用类型关键字
  • 各位大侠,请推荐几本在UNIX环境下使用标准C语言编程的好书.谢谢啊!!!
  • 我是一个linux新手,不知道如何在linux进行C语言的编写和使用?
  • 如何使用yacc分析c语言程序?
  • 菜鸟问题——其他语言怎样使用Java编写的程序(明确地说,使Class)
  • 在语言中,什么是共享内存,怎样使用,举例?
  • 如何使用c语言获取当前系统的时间,就是那个秒数?
  • ****请问谁有linux下c 语言函数的使用说明呀??要中文的!!!****
  • 在linux下,C语言编程,使用tell函数的问题
  • C语言中宏定义使用的小细节
  • linux使用c语言怎样实现程序唯一性
  • 汇编语言rep movsd 的使用详解
  • 2013年7月和2013年8月编程语言排行榜
  • 如何在GTK2.0下实现国际化(语言选择根据自己设置的语言,不用系统的语言)
  • 2017 年热门编程语言排行榜出炉,你的语言上榜没?
  • C语言中有指针,因此C语言可以创建链表,那么Java语言没有指针,那Java是否可以创建链表呢?
  • 苹果OS X和IOS下最新编程语言swift介绍
  • 求助,在linux下,c语言和汇编语言的接口是什么?
  • c语言判断某一年是否为闰年的各种实现程序代码
  • C语言中间语言 CIL
  • PHP编程语言介绍及安装测试方法
  • 最近学JSP,苦于HTML语言和JAVA语言太差,请教推荐几本书,thanks.


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3