亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

c語言尾隊列tailq使用示例分享

 更新時間:2014年01月28日 11:48:47   作者:  
這篇文章主要介紹了c語言尾隊列tailq使用示例,大家參考使用吧

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

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



使用示例

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

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

/*
  定義一個結(jié)構(gòu)體,它只是尾隊列的一個元素
  它必須包含一個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[])
{
 //定義一個結(jié)構(gòu)體指針
 struct tailq_entry *item;
 //定義另外一個指針
 struct tailq_entry *tmp_item;

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

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

  /*
     將元素加到隊列尾部
     參數(shù)1:指向隊列頭的指針
     參數(shù)2:要添加的元素
     參數(shù)3:結(jié)構(gòu)體的變量名
  */
  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);
   //釋放不需要的內(nèi)存單元
   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;

}

相關(guān)文章

  • LeetCode 單調(diào)棧內(nèi)容小結(jié)

    LeetCode 單調(diào)棧內(nèi)容小結(jié)

    這篇文章主要介紹了LeetCode 單調(diào)棧內(nèi)容小結(jié),本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-07-07
  • C/C++?-?從代碼到可執(zhí)行程序的過程詳解

    C/C++?-?從代碼到可執(zhí)行程序的過程詳解

    這篇文章主要介紹了C/C++?-?從代碼到可執(zhí)行程序的過程,主要有預(yù)編譯和編譯,匯編鏈接,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-01-01
  • C語言中浮點數(shù)的精度丟失問題解決

    C語言中浮點數(shù)的精度丟失問題解決

    大家好,本篇文章主要講的是C語言中浮點數(shù)的精度丟失問題解決,感興趣的同學(xué)趕快來看一看吧,對你有幫助的話記得收藏一下,方便下次瀏覽
    2022-01-01
  • C++中DeviceIoCteatol的用法實例

    C++中DeviceIoCteatol的用法實例

    這篇文章主要介紹了C++中DeviceIoCteatol的用法實例,對于學(xué)習(xí)C++針對硬件的操作有一定的參考借鑒價值,需要的朋友可以參考下
    2014-10-10
  • C語言基本排序算法之插入排序與直接選擇排序?qū)崿F(xiàn)方法

    C語言基本排序算法之插入排序與直接選擇排序?qū)崿F(xiàn)方法

    這篇文章主要介紹了C語言基本排序算法之插入排序與直接選擇排序?qū)崿F(xiàn)方法,結(jié)合具體實例形式分析了插入排序與直接選擇排序的定義、使用方法及相關(guān)注意事項,需要的朋友可以參考下
    2017-09-09
  • Qt通過圖片組繪制動態(tài)圖片

    Qt通過圖片組繪制動態(tài)圖片

    這篇文章主要為大家詳細(xì)介紹了Qt通過圖片組繪制動態(tài)圖片,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-07-07
  • C++ LARGE_INTEGER解析與使用案例詳解

    C++ LARGE_INTEGER解析與使用案例詳解

    這篇文章主要介紹了C++ LARGE_INTEGER解析與使用案例詳解,本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-08-08
  • Qt編寫地圖之實現(xiàn)跨平臺功能

    Qt編寫地圖之實現(xiàn)跨平臺功能

    這篇文章主要介紹了如何利用Qt編寫地圖應(yīng)用時實現(xiàn)跨平臺功能,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2022-02-02
  • C語言的多級指針你了解嗎

    C語言的多級指針你了解嗎

    這篇文章主要介紹了C語言中的多級指針,本文給大家介紹的非常詳細(xì),具有參考借鑒價值,需要的朋友可以參考下,希望能給你帶來幫助
    2021-08-08
  • C/C++回調(diào)函數(shù)介紹

    C/C++回調(diào)函數(shù)介紹

    回調(diào)函數(shù)就是一個通過函數(shù)指針調(diào)用的函數(shù)。如果你把函數(shù)的指針(地址)作為參數(shù)傳遞給另一個函數(shù),當(dāng)這個指針被用為調(diào)用它所指向的函數(shù)時,我們就說這是回調(diào)函數(shù)
    2013-10-10

最新評論