asp.net中CSharpThinking擴(kuò)展方法分析
本文實例講述了asp.net中CSharpThinking擴(kuò)展方法。分享給大家供大家參考。具體分析如下:
一、演變
① 擴(kuò)展方法特征
1)必須在一個靜態(tài)方法中。
2)至少有一個參數(shù)。
3)第一個參數(shù)必須附加this關(guān)鍵字作為前綴。
4)第一個參數(shù)不能有其他任何修飾符(如 out,ref)。
5)第一個參數(shù)的類型不能是指針。
6) 如果擴(kuò)展方法名稱與類型的方法一樣(如都命名為ToString),則只有類型的方法會被調(diào)用,而擴(kuò)展方法的不會,這是一個優(yōu)先級問題。
② 擴(kuò)展方法與普通靜態(tài)方法的比較
C#2 時對一個類進(jìn)行擴(kuò)展而又不能應(yīng)用繼承方式時,只能編寫稍微“丑陋”的靜態(tài)方法。C#3允許我們更改靜態(tài)類,來假裝方法是類與生俱來的。
{
// C#2 普通調(diào)用方式
string Log2 = ExtensionCompare.GetLogError("C#2 普通靜態(tài)方式");
Console.WriteLine(Log2);
// C#3 擴(kuò)展方法調(diào)用方式
string Log3 = "C#3擴(kuò)展方法方式".ToLogError();
Console.WriteLine(Log3);
Console.ReadLine();
}
/// <summary>
/// C#2 常規(guī)靜態(tài)方法擴(kuò)展
/// </summary>
/// <param name="loginfo">格式化信息</param>
/// <returns></returns>
public static string GetLogError(string loginfo)
{
return string.Format("This is C#2 style: {0}", loginfo);
}
/// <summary>
/// C#3 用擴(kuò)展方法實現(xiàn)的string類型擴(kuò)展
/// </summary>
/// <param name="loginfo"></param>
/// <returns></returns>
public static string ToLogError(this string loginfo)
{
return string.Format("This is C#3 style: {0}", loginfo);
}
二、擴(kuò)展方法最大的用途是在Linq中使用。
① Where , Select , OrderBy,
注:排序不會改變原序列的順序及類型,返回一個新序列,這與List.Sort不同,后者會改變序列。所以Linq是無副作用的,除了一些及其的特殊情況。
(dept => new
{
Name = dept.name,
Cost = dept.Employees.Sum(person=>person.Salary);
})
.OrderByDescending(x=>x.Cost);
② 擴(kuò)展方法更注重結(jié)果而非過程理解,這是與靜態(tài)方法的區(qū)別。
希望本文所述對大家的asp.net程序設(shè)計有所幫助。
相關(guān)文章
php基礎(chǔ)練習(xí)--簡單驗證碼實現(xiàn)
這篇文章主要介紹了php基礎(chǔ)練習(xí)--簡單驗證碼實現(xiàn),需要的朋友可以參考下2014-02-02
詳解ASP.NET Core 中的多語言支持(Localization)
本篇文章主要介紹了ASP.NET Core 中的多語言支持(Localization) ,具有一定的參考價值,有興趣的可以了解一下2017-08-08
asp.net結(jié)合Ajax驗證用戶名是否存在的代碼
關(guān)于Ajax的操作簡單總結(jié),結(jié)合Ajax驗證用戶名是否存在的代碼2010-06-06
使用JavaScript代碼實現(xiàn)各種數(shù)據(jù)控件的反選功能 不要只做拖控件的菜鳥
在我們做許多項目的時候,會用到反選這個功能,但是我一般使用C#代碼創(chuàng)建數(shù)組遍歷實現(xiàn)功能,今天我想換一種語言實現(xiàn)一下,于是我就用JavaScript研究了一下怎么實現(xiàn)這個功能2011-12-12
IIS處理Asp.net請求和Asp.net頁面生命周期詳細(xì)說明
ASP.NET 頁運行時,此頁將經(jīng)歷一個生命周期,在生命周期中將執(zhí)行一系列處理步驟。這些步驟包括初始化、實例化控件、還原和維護(hù)狀態(tài)、運行事件處理程序代碼以及進(jìn)行呈現(xiàn)2012-01-01
數(shù)據(jù)庫SqlParameter 的插入操作,防止sql注入的實現(xiàn)代碼
今天學(xué)習(xí)了一下SqlParameter的用法,原來這么寫是為了防止sql注入,破壞數(shù)據(jù)庫的。并自己動手連接了數(shù)據(jù)庫。2013-04-04

