a亚洲精品_精品国产91乱码一区二区三区_亚洲精品在线免费观看视频_欧美日韩亚洲国产综合_久久久久久久久久久成人_在线区

首頁 > 編程 > C > 正文

c語言尾隊(duì)列tailq使用示例分享

2020-01-26 15:37:47
字體:
供稿:網(wǎng)友

queue和list的結(jié)構(gòu)定義和操作都在'sys/queue.h'中完成, 主要定義了下面四種數(shù)據(jù)結(jié)構(gòu):

1單向列表(single-linked lists)
2單向尾隊(duì)列(single-linked tail queue)
3列表(lists)
4尾隊(duì)列(tail queues)



使用示例

復(fù)制代碼 代碼如下:

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

/*
  定義一個(gè)結(jié)構(gòu)體,它只是尾隊(duì)列的一個(gè)元素
  它必須包含一個(gè)TAILQ_ENTRY來指向上一個(gè)和下一個(gè)元素
*/
struct tailq_entry {
 int value;

 TAILQ_ENTRY(tailq_entry) entries;
};

//定義隊(duì)列的頭部
TAILQ_HEAD(, tailq_entry) my_tailq_head;

int main(int argc, char  *argv[])
{
 //定義一個(gè)結(jié)構(gòu)體指針
 struct tailq_entry *item;
 //定義另外一個(gè)指針
 struct tailq_entry *tmp_item;

 //初始化隊(duì)列
 TAILQ_INIT(&my_tailq_head);

 int i;
 //在隊(duì)列里添加10個(gè)元素
 for(i=0; i<10; i++) {
  //申請內(nèi)存空間
  item = malloc(sizeof(*item));
  if (item == NULL) {
   perror("malloc failed");
   exit(-1);
  }
  //設(shè)置值
  item->value = i;

  /*
     將元素加到隊(duì)列尾部
     參數(shù)1:指向隊(duì)列頭的指針
     參數(shù)2:要添加的元素
     參數(shù)3:結(jié)構(gòu)體的變量名
  */
  TAILQ_INSERT_TAIL(&my_tailq_head, item, entries);
 }

 //遍歷隊(duì)列
 printf("Forward traversal: ");
 TAILQ_FOREACH(item, &my_tailq_head, entries) {
  printf("%d ",item->value);
 }
 printf("/n");

 //添加一個(gè)新的元素
 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;
   //插入一個(gè)元素
   TAILQ_INSERT_AFTER(&my_tailq_head, item, new_item, entries);
   break;
  }
 }
 TAILQ_FOREACH(item, &my_tailq_head, entries) {
  printf("%d ", item->value);
 }
 printf("/n");

 //刪除一個(gè)元素
 printf("Deleting item with value 3: ");
 for(item = TAILQ_FIRST(&my_tailq_head); item != NULL; item = tmp_item) {
  if (item->value == 3) {
   //刪除一個(gè)元素
   TAILQ_REMOVE(&my_tailq_head, item, entries);
   //釋放不需要的內(nèi)存單元
   free(item);
   break;
  }
  tmp_item = TAILQ_NEXT(item, entries);
 }

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

 //清空隊(duì)列
 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;

}

發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 国产视频亚洲精品 | 男人久久天堂 | 亚洲成人影院在线观看 | 国产精品一区久久久久 | 色婷婷成人网 | 欧美日韩成人在线 | 精品亚洲精品 | 成人午夜sm精品久久久久久久 | 欧美一区二区三区四区视频 | 欧美aaaaa| 欧洲猛妇oooo | 亚洲 欧美日韩 国产 中文 | 国产馆一区二区 | 日本午夜网| 久久伊人成人 | 欧美一区在线看 | 国产精品一二三区 | 99在线免费视频 | 亚洲精品做爰大胆视频在线 | www.久久久 | 国产在线中文字幕 | 国产最新视频在线 | 亚洲成人av一区二区三区 | 国产精品免费看 | 国产精品久久久久久久裸模 | 日韩中文字幕在线观看 | 91视频免费网站 | 久久久久国产精品免费免费搜索 | 国产综合久久 | 久艹视频| 亚洲精品一区二区网址 | 久久久精品免费观看 | 欧美一级大片免费 | 视频一区在线播放 | 久久国产精彩视频 | 一级黄色在线 | 玖玖精品在线 | 久久国产精品99久久久久久牛牛 | 欧美一区2区三区4区公司二百 | 日韩视频区 | 亚洲综合在线一区二区 |