C#中除了Dictionary,List,HashSet,HashTable 還有哪些可以保存列表的數據類型?

在 C# 中,除了 DictionaryListHashSetHashtable 之外,還有許多其他可以保存列表或集合類型的數據結構,具體包括以下幾類:


📌 數組類

1. Array(數組)

  • 固定長度,性能高,適用于已知大小的數據集。
  • 適合頻繁訪問但不需要修改大小的場景。
 

csharp

int[] arr = new int[5] { 1, 2, 3, 4, 5 };

📌 列表類

2. Queue<T>(隊列)

  • 先進先出(FIFO)結構。
  • 適用于按順序處理任務的場景。
 

csharp

Queue<int> queue = new Queue<int>(); queue.Enqueue(1); int item = queue.Dequeue(); // 取出第一個元素

3. Stack<T>(棧)

  • 后進先出(LIFO)結構。
  • 適用于逆序或撤銷操作的場景。
 

csharp

Stack<int> stack = new Stack<int>(); stack.Push(1); int item = stack.Pop(); // 取出最后一個元素

4. LinkedList<T>(鏈表)

  • 雙向鏈表,支持在頭尾或中間快速插入和刪除操作。
  • 適用于頻繁插入和刪除的場景。
 

csharp

LinkedList<int> list = new LinkedList<int>(); list.AddFirst(1); list.AddLast(2);

📌 集合類

5. SortedSet<T>(有序集合)

  • 保證元素唯一性,并且自動按升序排序。
 

csharp

SortedSet<int> set = new SortedSet<int>(); set.Add(3); set.Add(1); set.Add(2); // 結果:1, 2, 3(自動排序)

6. ConcurrentBag<T>(線程安全集合)

  • 允許并發訪問的集合,適用于多線程場景。
 

csharp

ConcurrentBag<int> bag = new ConcurrentBag<int>(); bag.Add(1); bag.Add(2);

7. BlockingCollection<T>(阻塞集合)

  • 提供線程安全的生產者/消費者模式。
 

csharp

BlockingCollection<int> collection = new BlockingCollection<int>(); collection.Add(1); int item = collection.Take(); // 阻塞直到有數據

8. ObservableCollection<T>(可觀察集合)

  • 當集合發生變化時會觸發通知(通常用于數據綁定)。
 

csharp

ObservableCollection<int> observableList = new ObservableCollection<int>();
observableList.CollectionChanged += (sender, e) => 
{ Console.WriteLine("Collection changed"); 
}; 
observableList.Add(1);

📌 映射類

9. SortedDictionary<TKey, TValue>(有序字典)

  • 按鍵的升序排序,基于 Red-Black Tree 實現。
 

csharp

SortedDictionary<int, string> dict = new SortedDictionary<int, string>(); 
dict.Add(2, "B"); 
dict.Add(1, "A"); 
dict.Add(3, "C"); // 輸出順序為:1 -> 2 -> 3

10. SortedList<TKey, TValue>(有序列表)

  • 基于數組,按鍵排序,插入和刪除速度較慢。
 

csharp

SortedList<int, string> sortedList = new SortedList<int, string>(); 
sortedList.Add(1, "A"); 
sortedList.Add(2, "B");

11. ConcurrentDictionary<TKey, TValue>(線程安全字典)

  • 線程安全的鍵值對集合,適合在多線程場景下使用。
 

csharp

ConcurrentDictionary<int, string> dict = new ConcurrentDictionary<int, string>();
dict.TryAdd(1, "A");

📌 特殊集合類

12. BitArray(位數組)

  • 用于高效存儲和操作位(布爾值)。
 

csharp

BitArray bits = new BitArray(8); 
bits[0] = true;

13. NameValueCollection(鍵值對集合,允許重復鍵)

  • 允許鍵重復,存儲字符串鍵值對。
 

csharp

NameValueCollection collection = new NameValueCollection(); 
collection.Add("key", "value1"); 
collection.Add("key", "value2");

14. HybridDictionary(小規模時使用 ListDictionary,大規模時自動切換到 Hashtable

  • 在數據量少時使用 ListDictionary,大時切換為 Hashtable
 

csharp

HybridDictionary hybridDict = new HybridDictionary(); 
hybridDict.Add("key", "value");

15. ImmutableArray<T>, ImmutableList<T>, ImmutableDictionary<TKey, TValue>(不可變集合)

  • 定義后不可修改,適用于線程安全場景。
 

csharp

var immutableList = ImmutableList.Create(1, 2, 3); 
immutableList = immutableList.Add(4);

🔥 總結

數據結構特點適用場景
Array固定大小,訪問快固定長度數據集
List<T>可變長度,支持索引訪問隨機訪問和動態添加
LinkedList<T>雙向鏈表,插入/刪除快頻繁修改和插入
Stack<T>后進先出逆序操作
Queue<T>先進先出按順序處理任務
HashSet<T>元素唯一去重集合
SortedSet<T>唯一且排序唯一+排序
Dictionary<K,V>快速鍵值對訪問快速查找
SortedDictionary<K,V>按鍵排序排序+快速查找
ConcurrentBag<T>線程安全的集合并發訪問
ImmutableList<T>不可變集合線程安全

如果你要在多線程環境下操作,建議用 ConcurrentDictionaryConcurrentBagBlockingCollection
如果需要有序性,用 SortedListSortedDictionary
如果要去重,用 HashSetSortedSet

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/73196.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/73196.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/73196.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

《Python實戰進階》第21集:數據存儲:Redis 與 MongoDB 的使用場景

第21集&#xff1a;數據存儲&#xff1a;Redis 與 MongoDB 的使用場景 摘要 在現代應用開發中&#xff0c;數據存儲的選擇直接影響系統的性能、擴展性和成本。Redis 和 MongoDB 是兩種極具代表性的數據庫技術&#xff0c;它們分別擅長解決不同場景下的問題。本文將深入探討 Re…

三視圖轉stl導出 空心面片體 networkx shapely triangle numpy-stl

from shapely.geometry import Polygon import triangle from shapely.ops import unary_union from stl import mesh import numpy as np from collections import defaultdict from 三維投影線段尋找 import get_adjusted_clusters,get_clusters,get_intersect_lines import …

大摩閉門會:250312 學習總結報告

如果圖片分辨率不足&#xff0c;可右鍵圖片在新標簽打開圖片或者下載末尾源文件進行查看 本文只是針對視頻做相應學術記錄&#xff0c;進行學習討論使用

【51單片機】程序實驗15.DS18B20溫度傳感器

主要參考學習資料&#xff1a;B站【普中官方】51單片機手把手教學視頻 開發資料下載鏈接&#xff1a;http://www.prechin.cn/gongsixinwen/208.html 單片機套裝&#xff1a;普中STC51單片機開發板A4標準版套餐7 目錄 DS18B20介紹主要特性內部結構控制時序初始化時序寫時序讀時序…

ESP32芯片模組方案,設備物聯網無線通信,WiFi藍牙交互控制應用

在當下&#xff0c;物聯網正以前所未有的速度席卷全球&#xff0c;從繁華都市的智能建筑&#xff0c;到寧靜鄉村的智慧農業&#xff0c;從人們日常使用的可穿戴設備&#xff0c;到工業領域復雜精密的自動化生產線&#xff0c;物聯網的觸角已深入到生活與生產的每一個角落。 而…

Linux第二次練習

1.首先在根下面創建一個名為text的目錄 2.在根目錄下新建一個text目錄&#xff0c;然后在text目錄中新建上圖的一級目錄、二級目錄以及三級目錄 3.顯示/text目錄下文件的樹形拓撲圖 4.將linux樹狀結構圖中列出的所有文件用ll命令列出來

百雞問題-

百雞問題 #include<stdio.h> int main(){int n;scanf("%d",&n);int x,y,z;for(x0;x<100;x){for(y0;y<100;y){for(z0;z<100;z){if((x*15y*9z)<(3*n) && ((xyz)100)){printf("x%d,y%d,z%d\n",x,y,z);}}}}return 0; }

LVDS(Low Voltage Differential Signaling)電平詳解

一、LVDS的定義與核心特性 LVDS&#xff08;低壓差分信號&#xff09;是一種 低功耗、高速、抗干擾 的差分信號傳輸技術&#xff0c;通過一對互補的電壓信號&#xff08;正負端差值&#xff09;傳遞數據。其核心特性包括&#xff1a; 電氣特性 電壓擺幅&#xff1a;差分電壓約…

【OpenFeign 面試專題】

OpenFeign 面試專題 OpenFeign 的核心原理OpenFeign 如何與 Ribbon、Hystrix 集成Ribbon的負載均衡策略如何自定義 OpenFeign 的請求編碼和響應解碼OpenFeign 如何傳遞請求頭&#xff08;Header&#xff09;信息OpenFeign 如何處理超時和重試OpenFeign 支持哪些 HTTP 客戶端實現…

Adobe Acrobat Pro setting

防火墻斷網組織彈窗 Adobe軟件突然彈窗“THIS APP HAS BEEN DISABLED”&#xff1f;別慌&#xff0c;幾步教你輕松解決&#xff01; 禁用代理 解決Adobe出現This unlicensed Photoshop app has been disabled.禁止使用 rules:- DOMAIN-KEYWORD,adobe,REJECT

搜索插入位置(js實現,LeetCode:35)

給定一個排序數組和一個目標值&#xff0c;在數組中找到目標值&#xff0c;并返回其索引。如果目標值不存在于數組中&#xff0c;返回它將會被按順序插入的位置。 請必須使用時間復雜度為 O(log n) 的算法。 示例 1: 輸入: nums [1,3,5,6], target 5 輸出: 2示例 2: 輸入…

5. 前后端實現文件上傳與解析

1. 說明 在實際開發中&#xff0c;比較常見的一個功能是需要在前端頁面中選擇系統中的某個文件上傳到服務器中進行解析&#xff0c;解析后的文件內容可以用來在服務器中當作參數&#xff0c;或者傳遞給其它組件使用&#xff0c;或者需要存儲到數據庫中。所以本文就提供一種方式…

《靈珠覺醒:從零到算法金仙的C++修煉》卷三·天劫試煉(32)萬劍歸宗破妖陣 - 最長遞增子序列(LIS)

《靈珠覺醒:從零到算法金仙的C++修煉》卷三天劫試煉(32)萬劍歸宗破妖陣 - 最長遞增子序列(LIS) 哪吒在數據修仙界中繼續他的修煉之旅。這一次,他來到了一片神秘的萬劍谷,谷中有一座巨大的萬劍歸宗劍陣,劍陣閃爍著神秘的光芒。谷口有一塊巨大的石碑,上面刻著一行文字:…

【redis】使用redis作為緩存時所注意事項

緩存更新策略 在 Redis 緩存中&#xff0c;緩存的更新策略主要有**定期生成&#xff08;定時更新&#xff09;和實時生成&#xff08;即時更新&#xff09;**兩種方式。不同的策略適用于不同的業務場景&#xff0c;涉及性能、數據一致性和系統負載等方面的權衡。 1. 定期生成&…

計算機網絡:計算機網絡的分類

按分布范圍分類&#xff1a;廣域網&#xff0c;城域網&#xff0c;局域網&#xff0c;個域網 按傳輸技術分類&#xff1a;廣播式網絡&#xff0c;點對點網絡 按拓撲結構分類&#xff1a;總線型&#xff0c;環形&#xff0c;星形&#xff0c;網狀 按傳輸介質分類&#xff1a;…

解決pip安裝uv時下載速度慢

驗證優化效果 方案 1&#xff1a;臨時使用國內鏡像源&#xff08;推薦&#xff09; pip install uv -i https://pypi.tuna.tsinghua.edu.cn/simple 速度提升&#xff1a;鏡像源服務器位于國內&#xff0c;帶寬充足&#xff0c;通常可達 1-10MB/s 支持源列表&#xff1a; # 清…

SpringCloud Alibaba——入門簡介

一、是什么 &#xff08;1&#xff09;誕生 2018.10.31&#xff0c;Spring Cloud Alibaba 正式入駐了 Spring Cloud 官方孵化器&#xff0c;并在 Maven 中央庫發布了第一個版本 &#xff08;2&#xff09;介紹 &#xff08;3&#xff09;&#xff1f;何為必須組件 二、能干嘛…

Python完全指南:從基礎到實踐的編程藝術

引言&#xff1a;數字時代的瑞士軍刀 在人工智能與大數據浪潮中&#xff0c;Python如同編程世界的"瑞士軍刀"&#xff0c;以其優雅的語法和強大的生態征服全球開發者。本文將從語言哲學到實戰應用&#xff0c;為您展開Python編程的全景畫卷&#xff0c;揭示這門語言…

Docker 運行 GPUStack 的詳細教程

GPUStack GPUStack 是一個用于運行 AI 模型的開源 GPU 集群管理器。它具有廣泛的硬件兼容性&#xff0c;支持多種品牌的 GPU&#xff0c;并能在 Apple MacBook、Windows PC 和 Linux 服務器上運行。GPUStack 支持各種 AI 模型&#xff0c;包括大型語言模型&#xff08;LLMs&am…

完整例子和調用關系qt OpenGL

項目結構 首先&#xff0c;你需要在 Qt 項目中創建一個類&#xff0c;繼承自 QOpenGLWidget 來進行 OpenGL 渲染。文件結構如下&#xff1a; - main.cpp - MyOpenGLWidget.h - MyOpenGLWidget.cpp - vertex_shader.glsl - fragment_shader.glsl 1. main.cpp 這是 Qt 項目的入口…