欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

三十分鐘快速掌握C# 6.0知識點

 更新時間:2017年03月06日 14:11:01   作者:雨夜瀟湘  
這篇文章主要介紹了C# 6.0的相關(guān)知識點,文中介紹的非常詳細(xì),通過這篇文字可以讓大家在三十分鐘內(nèi)快速的掌握C# 6.0,需要的朋友可以參考借鑒,下面來一起看看吧。

一、只讀自動屬性(Read-only auto-properties)

 C# 6之前我們構(gòu)建只讀自動屬性:

 public string FirstName { get; private set; }
 public string LastName { get; private set; }

原理解析:就是編譯器在生成set訪問器時,它的修飾符是private,由上可知所謂的只讀只是針對類外部,在類內(nèi)部還是可以隨意修改屬性值的。

C# 6中提供了真正的只讀自動屬性,寫法如下:

 public string FirstName { get; }
 public string LastName { get; }

原理解析:首先編譯器會生成一個readonly的私有字段而get訪問器就是返回該字段的值,由上可知該只讀自動屬性只能在構(gòu)造函數(shù)中為其賦值。

二、自動屬性初始化器(Auto-Property Initializers)

以前自動屬性的賦值操作我們只能寫在方法中,如構(gòu)造函數(shù):

 public Student(string firstName, string lastName)
 {
 FirstName = firstName;
 LastName = lastName;
 }

但在C# 6中我們可以把賦值操作當(dāng)作聲明的一部份,如下所示:

 public string FirstName { get; set; } = "Corleone";
 public string LastName { get; set; } = "Mike";

備注:其實C# 6和之前的版本都一樣賦值操作最終都是在方法中完成,但后者明顯更簡潔直觀,所以這是個不錯的語法糖。

三、函數(shù)成員的表達(dá)式體(Expression-bodied function members)

C# 6中提供的一個新語法:對于只有一條語句的方法體可以簡寫成表達(dá)式。如下面兩種情況:

1. 方法(Methods)

 public Student Create() => new Student();

 

等同于:

 public Student Create()
 {
  return new Student();
 }

2. 只讀屬性(read only properties)

 public string FullName => string.Format("{0},{1}", FirstName, LastName);

等同于:

public string FullName
 {
  get
  {
   return string.Format("{0},{1}", FirstName, LastName);
  }
 }

原理解析:上面的表達(dá)式在編譯后會生成最原始的方法體和訪問器,值得一提的是函數(shù)表達(dá)式體跟Lambda是兩個相似但不相同的東西,函數(shù)的表

達(dá)式體只能帶一句話且不能包含return關(guān)鍵字但Lambda 能帶語句塊和包含關(guān)鍵字。

四、使用靜態(tài)(using static)

C# 6中的一個新語法:使用類型的靜態(tài)成員時可以省略其類型,如下所示:

 using static System.String;  // 先導(dǎo)入對應(yīng)成員類型
 public bool IsNull(string str) => IsNullOrEmpty(str); 

等同于:

 public bool IsNull(string str) => string.IsNullOrEmpty(str);

總結(jié):該語法糖的目的是使代碼變得更簡潔,但這個應(yīng)該是區(qū)分使用場景的,如:數(shù)學(xué)計算(Math類)使用此語法糖的確能夠簡潔代碼提高可讀

性,但在某處如果導(dǎo)入過多的類型那么不僅不能提高閱讀性反而會增加閱讀難度,因為你不知道這些成員具體屬于那個類型。還有若類型本身存在同名成員使用時則會使用類型成員覆蓋。

注意:使用靜態(tài)這一語法糖并不適用擴展方法,因為擴展方法的設(shè)計理念就是不修改已有代碼且只能在一定范圍內(nèi)使用,所以在特殊情況下需要將

其當(dāng)作靜態(tài)方法來使用,那么使用類名調(diào)用反而是比較明智的。

五、Null條件運算符(Null-conditional operators)

稍有經(jīng)驗的童鞋都知道在Coding過程中經(jīng)常要判斷變量的值是否為null,類似這種if-else的操作還不少。這使得代碼看起來十分不簡潔,好在C#6中提供了解決方法:

 var student = new Student();
 var firstName = student?.FirstName;

等同于:

var student = new Student();

 string firstName = null;
 if (student != null)
 {
  firstName = student.FirstName;
 }

使用方法:只需替換成員訪問符 . 為 ?. ,若 ?. 左邊為null則整個運算符的結(jié)果也為null,否則運算符的結(jié)果就等于其成員值。假如成員的類型為值

類型則整個表達(dá)式返回的類型是對應(yīng)類型的可空類型,如:

 int? age = student?.Age;

原理解析: ?. 編譯后就是 if 或 三元運算符,非賦值操作(如:call)會編譯成 if,賦值操作一般會編譯成三元運算符。

六、字符串插值(String Interpolation)

C# 6中提供了一種新語法來構(gòu)建格式化字符串,如:

 var fullName = $"{student.FirstName},{student.LastName}";

等同于:

 var fullName = string.Format("{0},{1}", student.FirstName, student.LastName);

使用方法:只需在字符串前加上$符號,然后在大括號中填寫表達(dá)式(字段、方法、Lambdad...)即可。

備注:

1. 字符串插值語法支持以前所有字符串格式設(shè)置,如:

 Console.WriteLine($"平均成績:{student.GPA:F2}");

注:因為 : 總被編譯器解釋為表達(dá)式與字符串格式的分隔符,所以表達(dá)式中若有條件運算符則我們需要用括號來強制編譯將其解析成當(dāng)前語境所要

表達(dá)的意義。如:

 Console.WriteLine($"平均成績:{(student.GPA > 80 ? student.GPA : 0):F2}");

2. 字符串插值語法可以嵌套,如:

 var score = $"我的各科成績:{ $"數(shù)學(xué):{student.MathScores};英語:{student.EnglishScore};"}";

原理解析:$"xxx{expression1}xxx{expression2}..." 編譯后就是string.Format()。

七、異常過濾器(Exception Filters)

C# 6中的一個新功能就是異常過濾器,它可以使我們在恰當(dāng)?shù)臅r機來應(yīng)用Catch子句,如:

try
 {
  throw new WebException("Request timed out..", WebExceptionStatus.Timeout);
 }
 catch (WebException webEx) when (webEx.Status == WebExceptionStatus.Timeout)
 {
  // Exception handling
 }

使用方法:try-catch() when()。

總結(jié):異常過濾器最大的亮點就是在使用恰當(dāng)?shù)那闆r下可以不丟失異常引發(fā)點的堆棧信息,這對程序的排錯至關(guān)重要。另外它還有很多有意思的用法,大家可以上網(wǎng)查下。

八、nameof表達(dá)式(nameof Expressions)

nameof 表達(dá)式的功能是獲取成員名稱,如拋異常:

public string FullName(Student student)
 {
  if (student == null)
   throw new ArgumentNullException(nameof(student));

  return $"{student.FirstName},{student.LastName}";
 }

優(yōu)點:nameof 表達(dá)式它能夠理解成員,當(dāng)成員被重命名時nameof表達(dá)式中也重命名了,而常量字符串表示法是沒有這樣的優(yōu)勢。

缺點:nameof 表達(dá)式生成的是不完全限定名,若你需要完全限定名 nameof 就不能幫你了。

原理解析:nameof 是編譯期間就確定其(成員)字符串名稱的,即編譯后就是常量字符串的表現(xiàn)形式了。

九、在Catch和Finally中使用Await(Await in Catch and Finally blocks)

C# 5 提供的 async 和 await 使異步編程變得極為簡便,但它們也有著局限性:await在catch和finally塊中不能使用。但這個問題已在C# 6中得到了解決,如:

public static async Task<string> MakeRequestAndLogFailures()
 {
  await logMethodEntrance();
  try
  {
   // ....
   var responseText = await streamTask;
   return responseText;
  }
  catch (System.Net.Http.HttpRequestException e) when (e.Message.Contains("301"))
  {
   await logError("Recovered from redirect", e);
   return "Site Moved";
  }
  finally
  {
   await logMethodExit();
  }
 }

十、Index初始化器(Index Initializers)

這個功能并沒有什么新意,其實以前就支持集合/字典 初始化器了,如:

var list = new List<string>()
 {
  "Mike",
  "Jim"
 };
 
 var dic = new Dictionary<int, string>()
 {
  { 20, "Mike" },
  { 30, "Jim" }
 };

在C# 6中只是字典初始化器支持了新的寫法,如:

 var dic = new Dictionary<int, string>()
 {
  [20] = "Mike",
  [30] = "Jim"
 };

總結(jié):暫無發(fā)現(xiàn)特殊的用法。

十一、改進(jìn)的重載解析—編譯器(Improved overload resolution)

 這算不上是新語法,因為僅僅是編譯器的改進(jìn),之所以一提是想讓大家知道有這么一回事。以前的編譯器是識別不了 Task.Run(Func<Task>())的,如下:

static Task DoThings()
 {
  return Task.FromResult(0);
 }
 
 Task.Run(DoThings); // 此處省略方法代碼...

上述代碼在老版本編譯器下是編譯不通過的,而在新版本編譯器是能編譯通過的。

備注:值得一提的是新版本編譯器也只是識別了Task.Run(Func<Task>()),Task.Run(Action) 還是識別不了,總的來說此功能對我們用處不大,

還不如乖乖的寫回Lambda表達(dá)式。

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

相關(guān)文章

  • .net(c#)中的new關(guān)鍵字詳細(xì)介紹

    .net(c#)中的new關(guān)鍵字詳細(xì)介紹

    在 C# 中,new 關(guān)鍵字可用作運算符、修飾符或約束
    2013-10-10
  • C#使用SqlSugarClient進(jìn)行數(shù)據(jù)訪問并實現(xiàn)了統(tǒng)一的批量依賴注入(示例代碼)

    C#使用SqlSugarClient進(jìn)行數(shù)據(jù)訪問并實現(xiàn)了統(tǒng)一的批量依賴注入(示例代碼)

    M為 BaseDto 請用C# 給出一個案例,支持不同表對應(yīng)不同的業(yè)務(wù)邏輯層,然后不同倉儲實例,不同表的業(yè)務(wù),都實現(xiàn)統(tǒng)一的批量依賴注入,下面通過示例給大家演示如何使用SqlSugarClient進(jìn)行數(shù)據(jù)訪問,并實現(xiàn)了統(tǒng)一的批量依賴注入,感興趣的朋友跟隨小編一起看看吧
    2024-05-05
  • 利用unity代碼C#封裝為dll的步驟分享

    利用unity代碼C#封裝為dll的步驟分享

    這篇文章主要給大家介紹了關(guān)于利用unity代碼C#封裝為dll的相關(guān)資料,文中通過圖文將實現(xiàn)的方法介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2018-05-05
  • C#在winform中實現(xiàn)數(shù)據(jù)增刪改查等功能

    C#在winform中實現(xiàn)數(shù)據(jù)增刪改查等功能

    本篇文章主要是介紹了C#在winform中操作數(shù)據(jù)庫,實現(xiàn)數(shù)據(jù)增刪改查,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-11-11
  • 利用WCF雙工模式實現(xiàn)即時通訊

    利用WCF雙工模式實現(xiàn)即時通訊

    這篇文章主要介紹了利用WCF雙工模式實現(xiàn)即時通訊的相關(guān)資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-09-09
  • C#編寫Windows服務(wù)實例代碼

    C#編寫Windows服務(wù)實例代碼

    本篇文章主要介紹使用Microsoft Visual Studio2012可以很方便的創(chuàng)建一個Windows服務(wù),本例實現(xiàn)一個向D盤的txt文件里,寫入系統(tǒng)時間的Windows服務(wù)
    2013-10-10
  • C#四舍五入用法實例

    C#四舍五入用法實例

    這篇文章主要為大家詳細(xì)介紹了C#四舍五入用法實例,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-02-02
  • C#基于Sockets類實現(xiàn)TCP通訊

    C#基于Sockets類實現(xiàn)TCP通訊

    這篇文章主要為大家詳細(xì)介紹了C#基于Sockets類實現(xiàn)TCP通訊,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-01-01
  • C#算法之無重復(fù)字符的最長子串

    C#算法之無重復(fù)字符的最長子串

    這篇文章介紹了C#算法之無重復(fù)字符的最長子串,文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-01-01
  • 如何保存Unity中的Log日志

    如何保存Unity中的Log日志

    這篇文章主要介紹了如何保存Unity中的Log日志的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-04-04

最新評論