C# 7.0 新特性1之基于Tuple的“多”返回值方法
原文鏈接:http://www.cnblogs.com/ylvict/p/5573094.html
回顧
首先,提出一個(gè)問(wèn)題,C#中,如何使一個(gè)方法可返回"多個(gè)"返回值?
我們先來(lái)回顧一下C#6.0 及更早版本的做法。
在C#中,通常我們有以下4種方式使一個(gè)方法返回多條數(shù)據(jù)。
•使用 KeyValue 組合
•
static void Main(string[] args)
{
int int1 = 15;
int int2 = 25;
var result = Add_Multiply(int1, int2);
Console.WriteLine(result.Key);
Console.WriteLine(result.Value);
}
private static KeyValuePair<int, int> Add_Multiply(int int1, int int2)
{
var KeyValuePair = new KeyValuePair<int, int>(int1 + int2, int1 * int2);
return KeyValuePair;
}
•使用 ref/out 參數(shù)
•Ref
•
static void Main(string[] args)
{
int int1 = 15;
int int2 = 25;
int add = 0;
int multiply = 0;
Add_Multiply(int1, int2, ref add, ref multiply);
Console.WriteLine(add);
Console.WriteLine(multiply);
}
private static void Add_Multiply(int int1, int int2, ref int add, ref int multiply)
{
add = int1 + int2;
multiply = int1 * int2;
}
•Out
•
static void Main(string[] args)
{
int int1 = 15;
int int2 = 25;
int add = 0;
int multiply = 0;
Add_Multiply(int1, int2, out add, out multiply);
Console.WriteLine(add);
Console.WriteLine(multiply);
}
private static void Add_Multiply(int int1, int int2, out int add, out int multiply)
{
add = int1 + int2;
multiply = int1 * int2;
}
•使用 struct 或者 class •struct
•
struct Result
{
public int add;
public int multiply;
}
static void Main(string[] args)
{
int int1 = 53;
int int2 = 17;
var result = Add_Multiply(int1, int2);
Console.WriteLine(result.add);
Console.WriteLine(result.multiply);
}
private static Result Add_Multiply(int int1, int int2)
{
var result = new Result
{
add = int1 + int2,
multiply = int1 * int2
};
return result;
}
•class
•
class Result
{
public int add;
public int multiply;
}
static void Main(string[] args)
{
int int1 = 13;
int int2 = 27;
var result = Add_Multiply(int1, int2);
Console.WriteLine(result.add);
Console.WriteLine(result.multiply);
}
private static Result Add_Multiply(int int1, int int2)
{
var result = new Result
{
add = int1 + int2,
multiply = int1 * int2
};
return result;
}
•dynamic
•
static void Main(string[] args)
{
int int1 = 13;
int int2 = 27;
var result = Add_Multiply(int1, int2);
Console.WriteLine(result.add);
Console.WriteLine(result.multiply);
}
private static dynamic Add_Multiply(int int1, int int2)
{
var result = new
{
add = int1 + int2,
multiply = int1 * int2
};
return result;
}
•使用 Tuple
•
static void Main(string[] args)
{
int int1 = 25;
int int2 = 28;
var result = Add_Multiply(int1, int2);
Console.WriteLine(result.Item1);
Console.WriteLine(result.Item2);
}
private static Tuple<int, int> Add_Multiply(int int1, int int2)
{
var tuple = new Tuple<int, int>(int1 + int2, int1 * int2);
return tuple;
}
Okay, 回顧的廢話有些多了。我們來(lái)看看C#7.0中的寫(xiě)法
新特性(C#7.0)
老規(guī)矩,先上代碼
static void Main(string[] args)
{
int int1 = 25;
int int2 = 28;
var result = Add_Multiply(int1, int2);
Console.WriteLine($"Add: {result.add}, Multiply: {result.multiply}");
//(var add, var multiply) = Add_Multiply(int1, int2);
//Console.WriteLine($"Add: {add}, Multiply: {multiply}");
}
public (int add, int multiply) Add_Multiply(int int1, int int2)
=> (int1 + int2, int1 * int2);
怎么樣?比起6.0及以前的C#,有沒(méi)有一種非常清爽的感覺(jué)。
其實(shí)只是基于Tuple 做了語(yǔ)法簡(jiǎn)化的語(yǔ)法糖罷了,只是給人一種多個(gè)返回值的錯(cuò)覺(jué)。
總結(jié):
這個(gè)特性雖然不是多么振奮人心的變化,但是解決了之前很多碼農(nóng)的一些癢點(diǎn)。
1. 看看KeyValue對(duì)的方式,本來(lái)很簡(jiǎn)單的一個(gè)操作,寫(xiě)出來(lái)的代碼會(huì)顯得非常的笨拙,取值的時(shí)候又根據(jù)Key獲取。而且,最重要的是,如果不在運(yùn)行時(shí),外面調(diào)用的代碼是不知道有那些Key的。
2. 再說(shuō)Ref/Out,這種方式應(yīng)該是傳統(tǒng)意義上最流行的寫(xiě)法了。甚至C#7.0的該特性,也無(wú)法取締ref在一定情景下的性質(zhì)。但至少在ref用于返回值這種情況下,代碼體現(xiàn)出的風(fēng)格明顯是和實(shí)際邏輯不符合的,明明是返回值,卻要以參數(shù)的形式進(jìn)出,非常不合理。
3. struct和class的方式就不多說(shuō)了,如果你針對(duì)的是一個(gè)實(shí)體,還能講得通,但如果本身目的是返回多個(gè)相關(guān)性不大的數(shù)據(jù),專門(mén)為方法間傳遞而加一個(gè)本沒(méi)有用處的Model類或結(jié)構(gòu),只能說(shuō)是當(dāng)時(shí)解決方案下的無(wú)奈。dynamic雖然從表現(xiàn)形式上沒(méi)有這種問(wèn)題,但是存在更坑的問(wèn)題是,除非在運(yùn)行時(shí),否則外部調(diào)用代碼根本不知道方法里傳出來(lái)什么。
4. 說(shuō)到傳統(tǒng)的Tuple,其實(shí)是和該特性最接近的了,但是看看調(diào)用時(shí)的*.Item1,*.Item2 。。天知道都是何物。即使在實(shí)現(xiàn)方法里,也讓人面對(duì)這種只見(jiàn)類型不見(jiàn)實(shí)際意義的值表示一頭霧水。
最后,解釋一下,目前(2016年6月)C#7.0還未正式發(fā)布,大家如果想體驗(yàn)部分特性,可以去下載VS15預(yù)覽版,最終發(fā)布的語(yǔ)法可能和本文中提及的有說(shuō)不同,最新動(dòng)態(tài)請(qǐng)大家關(guān)注Roslyn項(xiàng)目。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- C# ODP.NET 調(diào)用Oracle函數(shù)返回值時(shí)報(bào)錯(cuò)的一個(gè)解決方案
- C# WebApi 接口返回值不困惑:返回值類型詳解
- webBrowser執(zhí)行js的方法,并返回值,c#后臺(tái)取值的實(shí)現(xiàn)
- C#調(diào)用存儲(chǔ)過(guò)程詳解(帶返回值、參數(shù)輸入輸出等)
- C#中ExecuteNonQuery()返回值注意點(diǎn)分析
- C#一個(gè)方法返回多個(gè)值示例
- C#獲取存儲(chǔ)過(guò)程返回值和輸出參數(shù)值的方法
- C#?函數(shù)返回多個(gè)值的方法詳情
相關(guān)文章
C#中SQL參數(shù)傳入空值報(bào)錯(cuò)解決方案
這篇文章主要介紹了C#中SQL參數(shù)傳入空值報(bào)錯(cuò)解決方案,需要的朋友可以參考下2017-06-06
C#基于Aspose.PDF實(shí)現(xiàn)PDF轉(zhuǎn)Word工具
這篇文章主要為大家介紹了C#如何基于Aspose.PDF庫(kù),實(shí)現(xiàn)PDF文件轉(zhuǎn)為Word(DOC/DOCX)格式的功能,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-11-11
C#中利用LINQ to XML與反射把任意類型的泛型集合轉(zhuǎn)換成XML格式字符串的方法
本文主要介紹了C#中利用LINQ to XML與反射把任意類型的泛型集合轉(zhuǎn)換成XML格式字符串的方法:利用反射,讀取一個(gè)類型的所有屬性,然后再把屬性轉(zhuǎn)換成XML元素的屬性或者子元素。下面注釋比較完整,需要的朋友可以看下2016-12-12
C# 實(shí)現(xiàn)Trim方法去除字符串前后的所有空格
這篇文章主要介紹了C# 實(shí)現(xiàn)Trim方法去除字符串前后的所有空格,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-12-12

