C#學習筆記11

来源:http://www.cnblogs.com/zwt-blog/archive/2017/01/23/6344751.html
-Advertisement-
Play Games

1.List.BinarySearch():BinarySearch()採用的是二分搜索演算法,要求元素已經排好序,其特點是假如元素沒有找到,會返回一個負整數,該值的按位取反(~)結果是“大於被查找元素的下一個元素”的索引,如果沒有更大的值,則是元素的總數。這樣一來就可以在列表中的特定位置方便地插入新 ...


1.List.BinarySearch():BinarySearch()採用的是二分搜索演算法,要求元素已經排好序,其特點是假如元素沒有找到,會返回一個負整數,該值的按位取反(~)結果是“大於被查找元素的下一個元素”的索引,如果沒有更大的值,則是元素的總數。這樣一來就可以在列表中的特定位置方便地插入新值,同時保持已排序的狀態。可查看CollecationData.TestBinarySearch()代碼。要註意的是,假如事先沒有排好序,那麼不一定能找到一個元素,即是它確實在列表中。

2.Dictionary<TKey,TValue>的賦值:其賦值有2種方式,

(1)使用Add()方法添加鍵值對元素,但是若添加了一個相同的鍵值,會引發一個異常。

(2)使用索引器賦值,如dictionary[key]=value,若沒有該鍵值則進行添加,若有該鍵值則進行覆蓋。

3.字典類是沒有特定的順序,元素使用散列碼存到一個散列表中,這樣可以實現快速檢索。所以如果使用foreach迴圈來遍歷一個字典類,將不按照特定的順序來訪問值。

4.已排序的集合類:SortedDictionary<TKey,TValue>和SortedList<T>,對SortedDictionary<TKey,TValue>元素是按照鍵排序的,對SortedList<T>元素是按照值排序的。在一個已排序的集合中插入或刪除元素時,由於要保持集合中的元素順序,所以相對前面描述的普通集合,執行時間要稍長一些。可查看CollecationData.TestSortedDictionary()代碼。

5.棧集合類Stack<T>:其元素是先進後出,三個關鍵的方法是Push()、Pop()、Peek(),

(1)Push()將元素送入集合,元素不必是唯一的;

(2)Pop()按照與添加時相反的順序獲取並刪除元素;

(3)Peek()返回Pop()將獲取的下一個元素,但不修改棧中元素。

6.列隊集合Queue<T>:其元素遵循先入先出(元素不必是唯一的),使用Enqueue()進行入隊與Dequeue()進行出隊(出隊會移除元素),相當於一個管子的兩端。列隊集合根據需要自動增大,當不再需要數據的時候,我們使用TrimToSize()方法來恢復以前的容量。

7.索引運算符:使用this[參數]進行聲明,內中含有get與set,索引運算符可以獲取多個參數,甚至可以重載。C#編譯器為索引運算符創建的CIL代碼是一個名為Item的特殊屬性索引器在CIL代碼中的屬性名稱預設為Item,但是可以使用IndexerName(標記屬性)來指定一個不同的名稱,當然在實際使用中並無區別,它是它為不直接支持索引器的語言指定了名稱。編譯器能檢查到這個特性,但是IndexerName標記屬性本身是不會在CIL輸出中出現的,所以不能通過反射來使用它。

8.迭代器(yield)是如何工作的:C#編譯器遇到一個迭代器時,會根據枚舉數模式將代碼展開成恰當的CIL,在生成的代碼中,C#編譯器首先創建一個嵌套的private類來實現IEnumerator<T>介面,以及它的Current屬性和一個MoveNext()方法,Current屬性返回與迭代器的返回類型對應的一個類型。

9.單個類創建多個迭代器(yield):有時候可能希望不同的迭代順序、比如逆向迭代、對結果進行篩選等,為了在類中聲明額外的迭代器,你可以把它們封裝到返回IEnumerable<T>或IEnumrable的屬性或方法中。

10.yield語句的特征:只有在返回IEnumerator<T>或者IEnumerable<T>類型的成員中,才能聲明yield return 語句。更具體地說,只有在返回IEnumerator<T>的GetEnumerator()方法中,或者在返回IEnumerable<T>但不叫做GetEnumerator()的方法中,才能聲明yield return。

public class CollecationData
{
    public static void TestBinarySearch()
    {
        List<string> list = new List<string>() { "public", "protected", "private" };
        string item = "protected internal";
        list.Sort();
        int index = list.BinarySearch(item);
        if (index < 0)
        {
            list.Insert(~index, item);
        }
        list.ForEach(Console.WriteLine);
    }

    public static void TestSortedDictionary()
    {
        SortedDictionary<string, string> sortDict = new SortedDictionary<string, string>();
        int index = 0;
        sortDict.Add(index++.ToString(), "object");
        sortDict.Add(index++.ToString(), "byte");
        sortDict.Add(index++.ToString(), "uint");
        sortDict.Add(index++.ToString(), "ulong");
        sortDict.Add(index++.ToString(), "float");
        sortDict.Add(index++.ToString(), "char");
        sortDict.Add(index++.ToString(), "bool");
        sortDict.Add(index++.ToString(), "ushort");
        sortDict.Add(index++.ToString(), "decimal");
        sortDict.Add(index++.ToString(), "int");
        sortDict.Add(index++.ToString(), "sbyte");
        sortDict.Add(index++.ToString(), "short");
        sortDict.Add(index++.ToString(), "long");
        sortDict.Add(index++.ToString(), "void");
        sortDict.Add(index++.ToString(), "double");
        sortDict.Add(index++.ToString(), "string");
        Console.WriteLine("key  value   Hashcode");
        Console.WriteLine("---  -----   --------");
        foreach (KeyValuePair<string, string> item in sortDict)
        {
            Console.WriteLine("{0,-5}{1,-9}{2}", item.Key, item.Value, item.Key.GetHashCode());
        }
    }

    public static void TestDict()
    {
        Dictionary<string, string> dict = new Dictionary<string, string>();
        dict["1"] = "";
        dict.Add("2", "");
        foreach (var item in dict)
        {
            Console.WriteLine("key = {0} , value = {1}",item.Key,item.Value);
        }
    }
}

-------------------以上內容根據《C#本質論 第三版》進行整理


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

-Advertisement-
Play Games
更多相關文章
  • 1.chgrp,chown,chmod(-R遞歸修改文件夾下的文件) chgrp:修改文件屬於哪個組 chown:修改文件屬於哪個用戶 chmod:修改文件許可權r=4,w=2,x=1 chmod 4+2+1 file 如果不知道文件許可權可直接加許可權 比如 chmod a±rwx(a代表所有用戶,g代 ...
  • 要求:取指定目錄下麵的所有圖片,以表格的型式展示並顯示該圖片的相對路徑。 服務端代碼: 前端代碼: 效果圖如下: ...
  • 3. 添加一個視圖 · 原文地址:http://www.asp.net/mvc/tutorials/mvc-4/getting-started-with-aspnet-mvc4/adding-a-view · 譯文地址:http://www.cnblogs.com/powertoolsteam/ar ...
  • 2. 添加一個控制器 · 原文地址:http://www.asp.net/mvc/tutorials/mvc-4/getting-started-with-aspnet-mvc4/adding-a-controller · 譯文地址:http://www.cnblogs.com/powertools ...
  • 1.平臺互操作性和不安全的代碼:C#功能強大,但有些時候,它的表現仍然有些“力不從心”,所以我們只能摒棄它所提供的所有安全性,轉而退回到記憶體地址和指針的世界。 C#通過3種方式對此提供支持。 (1)第一種方式是通過平臺調用(Platform Invoke,P/Invoke)來調用非托管代碼DLL所公 ...
  • Socket裡面的協議解析是Socket通訊程式設計中最複雜的地方,如果你的應用層協議設計或實現不佳,Socket通訊中常見的粘包,分包就難以避免。SuperSocket內置了命令行格式的協議CommandLineProtocol,如果你使用了其它格式的協議,就必須自行實現自定義協議CustomPr ...
  • 1.在多個線程的同步數據中,避免使用this、typeof(type)、string進行同步鎖,使用這3個容易造成死鎖。 2.使用Interlocked類:我們一般使用的互斥鎖定模式(同步數據)為Lock關鍵字(即Monitor類),這個同步屬於代價非常高的一種操作。除了使用Monitor之外,還有 ...
  • 1.Task概述:Task是對操作系統線程的抽象,目的是使線程池能高效地管理線程的分配和回收,Task使用的底層線程屬於一種共用資源,任務需要互相協作,並及時歸還線程,以便用相同的共用資源(線程)滿足其他請求。 2.Task.AsyncState:獲取在創建 Task 時提供的狀態對象,如果未提供, ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...