您好,登錄后才能下訂單哦!
如何分析CLR Via的方法及參數(shù),相信很多沒有經(jīng)驗的人對此束手無策,為此本文總結(jié)了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個問題。
通常我們在使用方法的時候,方法的參數(shù)是按值傳遞的,如果傳遞的參數(shù)是引用類型的對象,是將引用對象的地址傳給方法。如果傳遞的是值類型實例,傳遞給方法的是該實例的一個副本。CLR Via允許使用在方法中按引用來傳遞參數(shù),C#中使用out和ref關(guān)鍵字來體現(xiàn)。下面就來介紹out和ref的使用。
1、CLR Via之out
(1)使用out時在方法的參數(shù)定義和方法的調(diào)用時都要用out關(guān)鍵字,如下:
static void Main(string[] args) { string name = string.Empty; GetStr(out name); //調(diào)用時加out Console.WriteLine(name); } private static void GetStr(out string name) //方法參數(shù)定義時的out { name = "oec2003"; }
(2)如果一個方法有out修飾的參數(shù),在方法結(jié)束前必須給給參數(shù)賦值,否則不能通過編譯,代碼如下:
static void Main(string[] args) { string name = "oec2003"; GetStr(out name); Console.WriteLine(name); } private static void GetStr(out string name) { //沒有給name賦值,編譯時會出現(xiàn)“控制離開當(dāng)前方法之前必須對 out 參數(shù)“name”賦值”異常 }
(3)在調(diào)用有out參數(shù)的方法時,沒有必要給out參數(shù)賦初始值,因為賦的值不會傳遞到方法的內(nèi)部,如果在方法的內(nèi)部要強行使用out參數(shù)會有編譯錯誤。代碼看下面,通常我們需要在一個方法中返回多個值的時候就可以使用out參數(shù)。和out參數(shù)一樣,使用ref時在方法的參數(shù)定義和方法的調(diào)用時都要用ref關(guān)鍵字。和out不同的是ref參數(shù)的值可以傳入方法內(nèi)進(jìn)行操作。
static void Main(string[] args) { string name = "oec2003"; //給out參數(shù)name賦初始值oec2003 GetStr(out name); Console.WriteLine(name); } private static void GetStr(out string name) { name = "hello" + name; //name在調(diào)用前雖賦值為oec2003 , //但此處會報錯“使用了未賦值的 out 參數(shù)name” }
(4)如果兩個方法的參數(shù)個數(shù)和類型都相同,區(qū)別只是其中一個為out參數(shù),那么這兩個方法是可以進(jìn)行重載的,下面的代碼可以正常運行。
2、CLR Via之ref
private static void GetStr(out string name) { name = "oec2003"; } private static void GetStr(string name) { name = "oec2003"; }
(1)如果調(diào)用方法前,ref參數(shù)沒有賦初始值,不能通過編譯,看如下代碼:
static void Main(string[] args) { string name; GetStr(ref name); //如果name沒有賦值不能通過編譯 Console.WriteLine(name); } private static void GetStr(ref string name) { name = "oec2003"; } static void Main(string[] args) { string name="oec2003"; GetStr(ref name); Console.WriteLine(name);//返回:hello oc2003 } private static void GetStr(ref string name) { name = "hello " + name; }
(2) 因為ref在傳入方法時會有初始值,所以在方法的內(nèi)部可以不對ref參數(shù)進(jìn)行任何的操作,那樣ref參數(shù)的值不會改變。
static void Main(string[] args) { string name="oec2003"; GetStr(ref name); Console.WriteLine(name);//在方法中沒有操作,仍然返回oec2003 } private static void GetStr(ref string name) { ...... }
(3)同out參數(shù)一樣,如果兩個方法的參數(shù)個數(shù)和類型都一樣,僅有的區(qū)別只是其中之一的參數(shù)為ref參數(shù),兩個可以進(jìn)行重載。
對于CLR Via來說,關(guān)鍵字out和關(guān)鍵字ref是等價的,就是說無論使用的out還是ref,都會生成相同的IL代碼,正因為如此,如果兩個方法的差異僅僅是out和ref的差異,那么這兩個方法是不能進(jìn)行重載的,如下代碼:
//下面代碼編譯會報“不能定義僅在 ref 和 out 上有差別的重載方法”異常 private static void GetStr(ref string name) { name = "oec2003"; } private static void GetStr(out string name) { name = "oec2003"; }
3、CLR Via之可變數(shù)量的參數(shù)
有些時候如果一個方法的參數(shù)數(shù)量可以根據(jù)用戶的需要而進(jìn)行變動,那將會帶來很大的方便。像String類型的Concat、Format等方法就提供了可變參數(shù)??梢宰儏?shù)在C#中使用params來定義,如下面代碼:
static void Main(string[] args) { Console.WriteLine(Add(1,2,3,4)); } public static int Add(params int[] num) { int sum = 0; foreach (int i in num) { sum += i; } return sum; }
使用可變參數(shù)非常簡單,需要注意的是可變參數(shù)的類型一定要是數(shù)組類型??勺儏?shù)雖然很好用,但是接受可變參數(shù)的方法在調(diào)用時會導(dǎo)致一些性能損失,以為數(shù)組對象必須分配在堆上,數(shù)組的內(nèi)存最終需要GC來回收。為了避免這種性能的損耗,我們在寫方法的時候可以多定義幾個沒有params關(guān)鍵字的方法的重載,這樣只有在很特殊的情況下才會使用有params關(guān)鍵字的方法。
4、CLR Via之方法的參數(shù)類型
聲明方法參數(shù)類型時,應(yīng)盡可能只用弱的類型,例如如果要編寫一個操作一組數(shù)據(jù)項的方法,***使用接口(如Ienumerable
//使用的弱類型參數(shù) private void OperateCollection<T>(IEnumerable<T> collection) { } //使用的強類型參數(shù) private void OperateCollection<T>(List<T> collection) { ...... }
此處所指的強類型和弱類型,可以理解為類型的層次,如果說父類的層次高于子類,那么層次越高就類型越弱。Iemumerable接口直接在 System.Collections 命名空間下,是其他一些集合類和接口(如Icollection IList List等)的基類,所以定義參數(shù)為IEnumerable 類型的,凡是繼承了IEnumerable 的類型的參數(shù)都能夠傳入方法,大大提高了靈活性。
看完上述內(nèi)容,你們掌握如何分析CLR Via的方法及參數(shù)的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注億速云行業(yè)資訊頻道,感謝各位的閱讀!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。