數據結構(三):隊列

来源:https://www.cnblogs.com/sheshouxin/archive/2019/04/15/10699317.html
-Advertisement-
Play Games

隊列:先入先出(FIFO)表。 常用操作: Enqueue:入隊,即將數據寫入隊列末尾 Dequeue:出隊,即將隊列開頭的元素從隊列中刪除並返回 應用場景: 隊列通常用來實現消息(任務)的快速讀寫,即消息隊列。消息隊列的常用來解決如下問題: 提升系統的吞吐量:通過引入消息隊列,將不是必須的業務邏輯 ...


隊列:先入先出(FIFO)表。

常用操作

  • Enqueue:入隊,即將數據寫入隊列末尾
  • Dequeue:出隊,即將隊列開頭的元素從隊列中刪除並返回

應用場景

  隊列通常用來實現消息(任務)的快速讀寫,即消息隊列。消息隊列的常用來解決如下問題:

  • 提升系統的吞吐量:通過引入消息隊列,將不是必須的業務邏輯非同步處理,用戶請求寫入消息隊列後即返迴響應,而不必等待全部的業務邏輯完成,提高了cpu利用效率。
  • 實現應用解耦:用戶請求通常是由一系列子業務系統配合完成,引入消息隊列,可以避免業務系統間直接的相互調用,從而實現應用解耦,各子系統間相互獨立,降低系統複雜度。
  • 流量削峰:類似秒殺的活動中,可以通過消息隊列控制活動人數,消息隊列滿後,直接拋棄用戶請求,緩解短時間內的高流量對伺服器的壓力。
  • 消息通訊:利用消息隊列高效的通訊機制,實現點對點通訊或聊天室。
  • 日誌處理:日誌採集客戶端將日誌寫入消息隊列,日誌處理伺服器從讀取消息隊列中的日誌,解決大量日誌傳輸問題。

實現方式

  • 鏈表實現:比較簡單,不再贅述
  • 數組實現:用數組實現一個隊列,需要考慮元素出隊後,數組位置單元迴圈利用的問題,即隊列的迴圈數組實現

使用迴圈數組實現一個隊列:

 1 from array import array
 2 
 3 class arr_queue(object):
 4     def __init__(self, maxsize):
 5         self._array = array('i', range(maxsize))
 6         self._head = 0
 7         self._tail = 0
 8         self._length = 0
 9         self._maxsize = maxsize
10 
11     def enqueue(self, value):
12         if self._length >= self._maxsize:
13             raise Exception('queue is full')
14         self._array[self._tail] = value
15         self._length += 1
16         self._tail += 1
17         if self._tail >= self._maxsize:
18             self._tail = 0
19 
20     def dequeue(self):
21         if self._length <= 0:
22             raise Exception('queue is empty')
23         value = self._array[self._head]
24         self._length -= 1
25         self._head += 1
26         if self._head >= self._maxsize:
27             self._head = 0
28         return value
29 
30     def __len__(self):
31         return self._length

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 前言 最近在做工作流的事情,正好有個需求,要添加一個附件上傳的功能,曾找過不少上傳插件,都不是特別滿意。無意中發現一個很好用的開源web文件管理器插件 elfinder,功能比較完善,社區也很活躍,還方便二次開發。 環境搭建 | 軟體 | 地址| | | | | SpringBoot| https: ...
  • 圖片比對 昨天的博客已經將圖片存儲到了本地,今天要做的第一件事情,就是需要在兩張圖片中進行比對,將圖片缺口定位出來 缺口圖片 完整圖片 計算缺口坐標 對比兩張圖片的所有RBG像素點,得到不一樣像素點的x值,即要移動的距離 極驗證對於用戶行為檢測是有專門的演算法的,找到一篇比較老的文章 https:// ...
  • 重構現有代碼:Refactoring 1.WHY SHOULD WE REFACTOR? 1.Refactoring Improves the Design of Software Without refactoring, the internal design—the architecture—o ...
  • 引子 最近遇到很多朋友過來咨詢G1調優的問題,我自己去年有專門學過一次G1,但是當時只是看了個皮毛,因此自己也有不少問題。總體來講,對於G1我有幾個疑惑,希望能夠在這篇文章中得到解決。 1. G1出現的初衷是什麼? 2. G1適合在什麼場景下使用? 3. G1的trade off是什麼? 4. G1 ...
  • python3字元串操作 ...
  • 今天繼續學習一下Numpy庫,廢話不多說,整起走 先說下Numpy中,經常會犯錯的地方,就是數據的複製 這個問題不僅僅是在numpy中有,其他地方也同樣會出現 先看看這段代碼,我們隨便建立了一個numpy數組 然後我想把a這個值,賦值給b,很簡單的操作,b = a 那麼我們列印一下b和a是不相等,返 ...
  • 第一周-第06章節-Python3.5-第一個python程式 G:\Python3.7.3\python.exe G:/practise/oldboy/day1/HelloWorld.pyHelloWorld!!! Process finished with exit code 0 第一周-第07 ...
  • Java8是自java5之後最重大的一次更新,它給JAVA語言帶來了很多新的特性(包括編譯器、類庫、工具類、JVM等),其中最重要的升級是它給我們帶來了Lambda表達式和Stream API。 1、什麼是Lambda表達式? Lambda是一個匿名函數,可以理解為是一段可以傳遞的代碼,可以將代碼像 ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...