雷火电竞-中国电竞赛事及体育赛事平台

歡迎來(lái)到入門教程網(wǎng)!

C語(yǔ)言

當(dāng)前位置:主頁(yè) > 軟件編程 > C語(yǔ)言 >

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

來(lái)源:本站原創(chuàng)|時(shí)間:2020-01-10|欄目:C語(yǔ)言|點(diǎn)擊:

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來(lái)指向上一個(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++) {
  //申請(qǐng)內(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;

}

上一篇:C語(yǔ)言堆棧入門指南

欄    目:C語(yǔ)言

下一篇:一個(gè)快速排序算法代碼分享

本文標(biāo)題:c語(yǔ)言尾隊(duì)列tailq使用示例分享

本文地址:http://www.jygsgssxh.com/a1/Cyuyan/3810.html

網(wǎng)頁(yè)制作CMS教程網(wǎng)絡(luò)編程軟件編程腳本語(yǔ)言數(shù)據(jù)庫(kù)服務(wù)器

如果侵犯了您的權(quán)利,請(qǐng)與我們聯(lián)系,我們將在24小時(shí)內(nèi)進(jìn)行處理、任何非本站因素導(dǎo)致的法律后果,本站均不負(fù)任何責(zé)任。

聯(lián)系QQ:835971066 | 郵箱:835971066#qq.com(#換成@)

Copyright © 2002-2020 腳本教程網(wǎng) 版權(quán)所有