国产精品久久久aaaa,日日干夜夜操天天插,亚洲乱熟女香蕉一区二区三区少妇,99精品国产高清一区二区三区,国产成人精品一区二区色戒,久久久国产精品成人免费,亚洲精品毛片久久久久,99久久婷婷国产综合精品电影,国产一区二区三区任你鲁

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

什么是隊列?不受類型限制的隊列如何實現

冬至配餃子 ? 來源:最后一個bug ? 作者:bug菌 ? 2022-08-12 09:22 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

1、初識size_t

這里可能大部分都不太知道有size_t這樣的一個數據類型,可以說該類型是英文size type的一個縮寫,它是一種記錄數據大小的數據類型(可以認為是一種整形數據)。其實我們經常使用的sizeof()的返回值數據類型就是size_t,只是我們常常用一個整形比如int來保存返回值。

值得我們注意得是:

sizeof類型是一個與操作系統相關得數據類型,它主要是為了提高C語言的可移植性和可讀性而加入的,可以說它并不是一種基本的數據類型,而且在頭文件中用typedef來重命名的數據類型。其實在我們平時很多地方都用到了size_t,比如:

poYBAGL1qh6AYh20AAAj7JvUFGA004.png

我們使用的時候幾乎都用整形比如int變量來使用,并沒有使用到size_t類型,所以說盡管我們的int依賴于C編譯器,有些情況size_t并不是固定的,如果我們用基本類型替換可能帶來數據類型過小或者過大的問題,過小可能會導致數據溢出問題,過大可能導致運行速度降低!
size_t的使用:只要是用到sizeof等返回值,或者傳入值的變量都定義為size_t類型!

2、什么是隊列?

隊列—

一種特殊的操作受限制得線性表,用戶僅允許在線性表的頭部獲取數據,在尾部插入數據,所以大家也叫FIFO(先進先出)線性表。

形象一點的表達

:類似于一隊人排隊鉆進一根只能進入一個人的管子,先進去的人先出來,后面的人只能在從同一個口子進入!

隊列的類型:

順序隊列和循環隊列。順序隊列,出隊列指針必須>或者=入隊列指針,否則容易出現假溢出現象;而循環隊列只要入隊列指針與出隊列指針不再次重合就不回溢出!

3、不受類型限制的隊列實現

首先我們先貼上剛剛寫好的Queue.h和Queue.c文件

poYBAGL1qnqAMV7gAAFKVcP9Sws614.png

pYYBAGL1qoGAYmiJAAFDHSF_4Hc866.png

poYBAGL1qoaACHUeAAESAE9aqkQ694.png

pYYBAGL1qo2AYiJoAAC53sBnHt8401.png

poYBAGL1qrqAIybVAADqgoePl0s061.pngpoYBAGL1qsGAbHMXAADP9acB7uY706.png

解析代碼:

1)節點數據結構中采用void類型的指針,能夠指向任意數據類型來擴展我們的隊列。

2)隊列數組順序隊列,我們可以通過修改擴展變成循環隊列,便于我們使用。

3)具體的使用可以參考上面的例子進行開發。

4、隊列的應用

1)隊列可以作為一種數據緩沖,當我們的數據無法實時進行發送的時候,可以進行適當的隊列緩沖,集中到一定的數據,然后進行打包發送。

2)隊列可以實現任務之間的一個信息交互,可以解決一些多線程問題,實現一種任務之間的異步處理。

3)由于是隊列的一個先進先出特點,我們也可以利用隊列來嚴格的控制數據的順序。



審核編輯:劉清

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 接口
    +關注

    關注

    33

    文章

    9521

    瀏覽量

    157050
  • C語言
    +關注

    關注

    183

    文章

    7644

    瀏覽量

    145614
  • 多線程
    +關注

    關注

    0

    文章

    279

    瀏覽量

    21033
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    RDMA設計43:隊列刪除及連接斷開功能測試

    在接收到正確的刪除隊列請求后,首先進入連接斷開流程,即四次揮手斷鏈,如圖中紅框部分。隨后進行隊列刪除操作。返回隊列操作狀態 0x2b,符合設計預期,驗證通過。
    的頭像 發表于 02-24 07:50 ?554次閱讀
    RDMA設計43:<b class='flag-5'>隊列</b>刪除及連接斷開功能測試

    RDMA設計25:隊列管理模塊之發送模塊詳細設計分析

    發送隊列存儲為所有發送隊列共用的存儲空間,根據用戶環境和開發板環境不同可由 BRAM、URAM 或 LUTRAM 實現。發送隊列管理單元則負責管理這個存儲空間,并處理用戶指令和發送
    的頭像 發表于 01-25 16:27 ?3373次閱讀
    RDMA設計25:<b class='flag-5'>隊列</b>管理模塊之發送模塊詳細設計分析

    RDMA設計26:隊列管理模塊設計之接收隊列模塊詳細分析

    本文主要交流設計思路,在本博客已給出相關博文100多篇,希望對初學者有用。注意這里只是拋磚引玉,切莫認為參考這就可以完成商用IP設計。 (2)接收隊列 接收隊列由一個接收隊列管理單元組成。與發送
    發表于 01-22 09:03

    RDMA設計24:隊列管理模塊設計

    隊列管理模塊采用管理與存儲分離的結構進行設計,由發送隊列存儲、發送隊列管理、接收隊列管理、完成條目解析、異常完成條目處理和 Round-Robin 仲裁組成。
    的頭像 發表于 01-20 11:45 ?1378次閱讀
    RDMA設計24:<b class='flag-5'>隊列</b>管理模塊設計

    RDMA設計18:隊列管理模塊設計3

    本文主要交流設計思路,在本博客已給出相關博文140多篇,希望對初學者有用。注意這里只是拋磚引玉,切莫認為參考這就可以完成商用IP設計。 (3)完成隊列 完成隊列的管理由完成條目解析單元和異常完成條目
    發表于 01-05 09:04

    RDMA設計17:隊列管理模塊設計2

    。 (2)接收隊列 接收隊列由一個接收隊列管理單元組成。與發送隊列類似的是,接收隊列管理單元也由若干表單構成,其中包括 RQ1 表單和用戶
    發表于 01-04 14:54

    C語言的循環隊列

    循環隊列(Circular Buffer) typedef struct { int buffer[SIZE]; int head; int tail; int count
    發表于 12-12 08:28

    NVMe高速傳輸之擺脫XDMA設計54:如何測試隊列管理功能2

    , 表示操作順序錯誤; 創建 I/O 完成隊列和提交隊列后, 先刪除完成隊列, 返回錯誤值為 8, 表示操作順序錯誤。 打印信息顯示測試結果與預期設計功能一致, 成功執行了隊列的創建和
    發表于 12-10 08:33

    優先級隊列介紹

    隊列(Queue)的知識點:「概念」:隊列是一種先進先出(FIFO)的數據結構,類似于排隊的概念。「基本操作」:enqueue(item): 將元素添加到隊列的末尾。dequeue(): 從
    發表于 11-26 07:56

    基于環形隊列的UART收發回顯實驗

    問題。在本實驗中,我們使用環形隊列實現實驗1的串口收發回顯,將串口接收到的數據暫存在隊列中,待完成一次接收后再將隊列中的數據全部發出去。
    的頭像 發表于 10-27 13:51 ?1985次閱讀
    基于環形<b class='flag-5'>隊列</b>的UART收發回顯實驗

    NVMe IP高速傳輸卻不依賴XDMA設計之九:隊列管理模塊(上)

    這是采用PCIe設計NVMe,并非調用XDMA方式,后者在PCIe4.0時不大方便,故團隊直接采用PCIe設計,結合UVM驗證加快設計速度。 隊列管理模塊采用隊列的存儲與控制分離的設計結構。
    的頭像 發表于 08-04 09:53 ?768次閱讀
    NVMe IP高速傳輸卻不依賴XDMA設計之九:<b class='flag-5'>隊列</b>管理模塊(上)

    NVMe高速傳輸之擺脫XDMA設計九:隊列管理模塊設計(上)

    條目,一個提交隊列管理單元用于實現提交隊列存儲地址空間的管理和門鈴控制。在提交隊列管理單元中,構建一個admin提交隊列表單和N個I/O提交
    發表于 07-27 17:41

    RabbitMQ消息隊列解決方案

    在現代分布式系統架構中,消息隊列作為核心組件,承擔著系統解耦、異步處理、流量削峰等重要職責。RabbitMQ作為一款成熟的消息隊列中間件,以其高可用性、高可靠性和豐富的特性,成為眾多企業的首選方案。本文將從運維工程師的角度,詳細闡述RabbitMQ從單機部署到集群搭建的完
    的頭像 發表于 07-08 15:55 ?634次閱讀

    NVME控制器之隊列管理模塊

    隊列管理模塊是整個NVMe Host控制器的核心模塊,該模塊實現了提交隊列與完成隊列的管理,多隊列請求的仲裁判決等功能。
    發表于 05-03 20:19

    NVME控制器之隊列管理模塊

    隊列管理模塊是整個NVMe Host控制器的核心模塊,該模塊實現了提交隊列與完成隊列的管理,多隊列請求的仲裁判決等功能。
    的頭像 發表于 05-03 15:32 ?661次閱讀
    NVME控制器之<b class='flag-5'>隊列</b>管理模塊