99精品伊人亚洲|最近国产中文炮友|九草在线视频支援|AV网站大全最新|美女黄片免费观看|国产精品资源视频|精彩无码视频一区|91大神在线后入|伊人终合在线播放|久草综合久久中文

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

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

3天內(nèi)不再提示

什么是隊列?不受類型限制的隊列如何實現(xiàn)

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

掃碼添加小助手

加入工程師交流群

1、初識size_t

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

值得我們注意得是:

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

poYBAGL1qh6AYh20AAAj7JvUFGA004.png

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

2、什么是隊列?

隊列—

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

形象一點的表達

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

隊列的類型:

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

3、不受類型限制的隊列實現(xiàn)

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

poYBAGL1qnqAMV7gAAFKVcP9Sws614.png

pYYBAGL1qoGAYmiJAAFDHSF_4Hc866.png

poYBAGL1qoaACHUeAAESAE9aqkQ694.png

pYYBAGL1qo2AYiJoAAC53sBnHt8401.png

poYBAGL1qrqAIybVAADqgoePl0s061.pngpoYBAGL1qsGAbHMXAADP9acB7uY706.png

解析代碼:

1)節(jié)點數(shù)據(jù)結(jié)構(gòu)中采用void類型的指針,能夠指向任意數(shù)據(jù)類型來擴展我們的隊列。

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

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

4、隊列的應用

1)隊列可以作為一種數(shù)據(jù)緩沖,當我們的數(shù)據(jù)無法實時進行發(fā)送的時候,可以進行適當?shù)年犃芯彌_,集中到一定的數(shù)據(jù),然后進行打包發(fā)送。

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

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



審核編輯:劉清

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

    關(guān)注

    33

    文章

    9000

    瀏覽量

    153713
  • C語言
    +關(guān)注

    關(guān)注

    180

    文章

    7632

    瀏覽量

    141674
  • 多線程
    +關(guān)注

    關(guān)注

    0

    文章

    279

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    RabbitMQ消息隊列解決方案

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

    從 app_gatt_callback調(diào)用這個隊列推送函數(shù)時,程序出現(xiàn)了硬故障怎么解決?

    我正在嘗試在 wiced BLE 堆棧中使用基于演員的設計模式。 因此,所有任務都使用消息隊列相互通信。 消息隊列將保存塊大小為 64 的內(nèi)存池指針的地址。 我維護著一個由這些池地址指針組成的隊列
    發(fā)表于 07-04 06:03

    精通 MQTT:消息隊列遙測傳輸指南!

    引言MQTT(消息隊列遙測傳輸)是一種輕量級消息協(xié)議,專為低帶寬、高延遲和不可靠的網(wǎng)絡環(huán)境設計。它廣泛應用于物聯(lián)網(wǎng)(IoT)應用、消息系統(tǒng)以及實時數(shù)據(jù)通信領(lǐng)域。本指南深入探討了MQTT的工作原理
    的頭像 發(fā)表于 06-16 16:56 ?478次閱讀
    精通 MQTT:消息<b class='flag-5'>隊列</b>遙測傳輸指南!

    RDMA簡介6之RoCEV2連接管理

    ? RoCE v2協(xié)議的隊列在創(chuàng)建時就已確定連接類型,共有兩種工作模式:主要分為兩種工作模式:有連接模式和無連接模式。在有連接模式下,支持可靠連接(RC)和不可靠連接(UC)兩種傳輸類型;而無連接
    發(fā)表于 06-13 09:50

    向FreeRTOS的任務中發(fā)送事件隊列是有什么限制嗎?

    到了TMC的芯片,但是在到位上報的信息中少了卡死電機的上報。所以有的電機的到位中斷并沒有成功寫入任務。 一開始是每個電機都開啟了一個定時器查詢,后續(xù)改成一個定時器查六個電機并將定時器的周期加到50ms,就很少會卡死。 所以向FreeRTOS的任務中發(fā)送事件隊列是有什么限制
    發(fā)表于 06-11 07:57

    RDMA簡介5之RoCE V2隊列分析

    工作隊列元素(WQE),該元素包括數(shù)據(jù)發(fā)送緩沖區(qū)的起始地址、數(shù)據(jù)長度、操作類型等相關(guān)信息,用于后續(xù)的傳輸操作。在該WQE被網(wǎng)卡操作結(jié)束后,網(wǎng)卡將生成一個CQE并放入與工作隊列(SQ)對應的完成
    發(fā)表于 06-05 17:28

    NVME控制器之隊列管理模塊

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

    NVME控制器之隊列管理模塊

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

    不受環(huán)境限制,MEMS尋北儀助力各領(lǐng)域實現(xiàn)高精度定向

    尋北儀可以通過地球自轉(zhuǎn)確定真北方向,可以為各種活動提供方位基準。它不受天氣、地點和磁場環(huán)境條件的限制,具有高精度、高可靠性和易于維護的特點?。
    的頭像 發(fā)表于 12-18 14:41 ?795次閱讀
    <b class='flag-5'>不受</b>環(huán)境<b class='flag-5'>限制</b>,MEMS尋北儀助力各領(lǐng)域<b class='flag-5'>實現(xiàn)</b>高精度定向

    JavaWeb消息隊列使用指南

    在現(xiàn)代的JavaWeb應用中,消息隊列(Message Queue)是一種常見的技術(shù),用于異步處理任務、解耦系統(tǒng)組件、提高系統(tǒng)性能和可靠性。 1. 消息隊列的基本概念 消息隊列是一種應用程序?qū)?/div>
    的頭像 發(fā)表于 11-25 09:27 ?520次閱讀

    探索字節(jié)隊列的魔法:多類型支持、函數(shù)重載與線程安全

    探索字節(jié)隊列的魔法:多類型支持、函數(shù)重載與線程安全代碼難度指數(shù):文章學習重點:參數(shù)宏的使用技巧一、引言在嵌入式系統(tǒng)和實時應用中,數(shù)據(jù)的傳輸和處理是至關(guān)重要的。字節(jié)隊列(ByteQueue)是一種重要
    的頭像 發(fā)表于 11-15 01:08 ?1236次閱讀
    探索字節(jié)<b class='flag-5'>隊列</b>的魔法:多<b class='flag-5'>類型</b>支持、函數(shù)重載與線程安全

    為什么同一個隊列引用的全局變量,運行在兩個子vi中發(fā)現(xiàn)隊列數(shù)據(jù)丟失了

    我創(chuàng)建了一個隊列,然后將隊列引用做了個全局變量,運行在兩個子vi中,一個是只入隊列,另一個是只出隊列。但我發(fā)現(xiàn),一個字vi數(shù)據(jù)入隊列成功,檢
    發(fā)表于 11-14 11:47

    eBPF技術(shù)實踐之virtio-net網(wǎng)卡隊列可觀測

    時,這一路徑難以進行觀測。一些復雜的網(wǎng)絡抖動問題很可能是由于網(wǎng)卡隊列不正常工作引起的。為了解決這類問題,我們基于eBPF技術(shù)擴展了網(wǎng)卡隊列的可觀測能力,使得virtio網(wǎng)卡前后端的定界問題不再困擾。 virtio-net 前后端驅(qū)動簡介 virtio-net (后面稱為
    的頭像 發(fā)表于 11-14 11:18 ?678次閱讀
    eBPF技術(shù)實踐之virtio-net網(wǎng)卡<b class='flag-5'>隊列</b>可觀測

    嵌入式環(huán)形隊列與消息隊列實現(xiàn)原理

    嵌入式環(huán)形隊列,也稱為環(huán)形緩沖區(qū)或循環(huán)隊列,是一種先進先出(FIFO)的數(shù)據(jù)結(jié)構(gòu),用于在固定大小的存儲區(qū)域中高效地存儲和訪問數(shù)據(jù)。其主要特點包括固定大小的數(shù)組和兩個指針(頭指針和尾指針),分別指向隊列的起始位置和結(jié)束位置。
    的頭像 發(fā)表于 09-02 15:29 ?1249次閱讀

    玩轉(zhuǎn)RT-Thread之消息隊列的應用

    在嵌入式系統(tǒng)開發(fā)中,實時處理串口和ADC數(shù)據(jù)是一項重要的任務。本文將介紹如何在RT-Thread實時操作系統(tǒng)中,利用消息隊列來同時處理來自串口和ADC的數(shù)據(jù)。通過這種方法,我們能夠高效地管理和處理
    的頭像 發(fā)表于 07-23 08:11 ?910次閱讀
    玩轉(zhuǎn)RT-Thread之消息<b class='flag-5'>隊列</b>的應用