首先咱們簡單瞭解一下什麼堆、棧、隊列。數組
堆是在程序運行時,而不是在程序編譯時,申請某個大小的內存空間。即動態分配內存,對其訪問和對通常內存的訪問沒有區別。this
棧就是一個容器,後放進去的先拿出來,它下面原本有的東西要等它出來以後才能出來。(先進後出or後進先出)spa
隊列只能在隊頭作刪除操做,在隊尾作插入操做.而棧只能在棧頂作插入和刪除操做。(先進先出)指針
注意:當前展現的是隊列(Queue),下一章展現消息隊列MQ(Message Queue)code
隊列(Queue)表明了一個先進先出的對象集合。當您須要對各項進行先進先出的訪問時,則使用隊列。orm
當您在列表中添加一項,稱爲入隊,當您從列表中移除一項時,稱爲出隊。對象
經常使用的屬性&描述blog
下面咱們結合一個實例進行簡單講解:隊列
實例:將用戶下單信息加入到隊列中並讀取隊列。內存
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; namespace QueueConsoleApplication { public class Program { //實例:將用戶下單信息加入到隊列中並讀取隊列。 static void Main(string[] args) { //建立一個隊列 Queue<UserInfo> queue = new Queue<UserInfo>(); //獲取用戶下單列表 List<UserInfo> userList = GetUserList(); //使用Enqueue()方法將用戶下單信息加入到隊列中(入列) foreach (var user in userList) { queue.Enqueue(user); } //使用Count屬性獲取隊列中元素個數 int queueCount = queue.Count; Console.WriteLine(string.Format("隊列中有{0}個用戶下單信息。", queueCount)); //輸出 //使用Dequeue()方法從隊列的頭部讀取和刪除元素(出列) for (int i = 0; i < queueCount; i++) { UserInfo user = queue.Dequeue(); Console.WriteLine(string.Format("\n單號:{0};用戶名稱:{1};手機號:{2};收貨地址:{3};商品名稱:{4};價格:{5}", user.ID, user.Name, user.Phone, user.Address, user.Commodity, user.Price)); } //使用Count屬性獲取隊列中元素的格式 queueCount = queue.Count; Console.WriteLine(string.Format("\n隊列中有{0}個用戶下單信息。", queueCount)); //輸出 } /// <summary> /// 獲取用戶列表 /// </summary> /// <returns></returns> public static List<UserInfo> GetUserList() { List<UserInfo> userList = new List<UserInfo>(); userList.Add(new UserInfo("201906031010", "王母", "1821234****", "崑崙山玉虛宮", "9萬年蟠桃", 136.00)); userList.Add(new UserInfo("201906031011", "喜洋洋", "1821235****", "青青草原羊村", "狼堡牌無毒除蟲劑", 198.00)); userList.Add(new UserInfo("201906031012", "光頭強", "1821236****", "狗熊嶺光頭強家", "捕獸夾", 346.00)); userList.Add(new UserInfo("201906031013", "孫悟空", "1821237****", "花果山", "去蝨粉", 245.00)); return userList; } } /// <summary> /// 用戶下單信息實體類 /// </summary> public class UserInfo { public UserInfo(string id, string name, string phone, string address, string commodity, double price) { this.ID = id; this.Name = name; this.Phone = phone; this.Address = address; this.Commodity = commodity; this.Price = price; } public string ID { get; set; } //單號 public string Name { get; set; } //姓名 public string Phone { get; set; } //手機號 public string Address { get; set; } //收貨地址 public string Commodity { get; set; } //商品名稱 public double Price { get; set; } //價格 } }
首先準備一個有內容的隊列,結合先進先出的原則,咱們讀取隊列裏面的消息進行打印。
入隊的信息能夠動態插入,咱們這裏演示就寫入指定數據。
運行代碼後咱們在控制檯打印相關信息,以下圖:
總結:
C#中提供了隊列類,用Queue類來表示,該類表示表示對象的先進先出集合,其位於System.Collections命名空間下。
隊列在按接收順序存儲消息方面很是有用,以便於進行順序處理。Queue類將隊列做爲循環數組實現,存儲在Queue類中的對象在一端插入,從另外一端移除。
這種方式不需其餘花裏胡哨的東西,新建好項目直接編寫代碼便可。
這個的源碼已經在上的代碼裏面了,直接拷貝運行就能夠的,
下面咱們講解消息隊列MQ(Message Queue),
這個就須要下載RabbitMQ、Erlang環境並安裝,下載RabbitMQ.Client客戶端進行引用,附帶源碼。