国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 編程 > C# > 正文

C#4.0的新特性

2023-05-20 20:23:35
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

vs2010正式版4月12日發(fā)布了,下面就幾個(gè)新特性與大家共享一下。

一、新關(guān)鍵詞 ——dynamic

在新版本的C#中,dynamic關(guān)鍵詞是一個(gè)很重要的新特性,現(xiàn)在你可以創(chuàng)建動(dòng)態(tài)對(duì)象并在運(yùn)行時(shí)再?zèng)Q定它的類型。而且.net 4.0為CLR加入了一組為動(dòng)態(tài)語(yǔ)言服務(wù)的運(yùn)行時(shí)環(huán)境,稱為DLR(Dynamic Language Runtime動(dòng)態(tài)語(yǔ)言運(yùn)行時(shí)),這使得C#這種靜態(tài)類型語(yǔ)言可以在 .NET Framework 中開(kāi)發(fā)動(dòng)態(tài)語(yǔ)言并為與其它動(dòng)態(tài)語(yǔ)言提供互操作性了。DLR架構(gòu)見(jiàn)下圖:

DLR架構(gòu)

關(guān)于DLR的更 詳細(xì)信息,可以參考msdn:http://msdn.microsoft.com/en-us/library/dd233052(VS.100).aspx

先來(lái)看看dynamic的一個(gè)例子: 

C# code

 
dynamic dyn = 1;
Console.WriteLine(dyn.GetType());
dyn
= 1.234;
Console.WriteLine(dyn.GetType());
dyn
= "ojlovecd";
Console.WriteLine(dyn.GetType());

/*
輸出:
System.Int32
System.Double
System.String

*/

 可能你會(huì)說(shuō),這個(gè)效果,我用object關(guān)鍵字就可以了,干嗎加個(gè)dynamic?那我們就來(lái)討論一下 object與dynamic的區(qū)別。

先看如下代碼: 

C# code

 

object obj = 10;
obj
= obj + 10;

這樣肯定是通不過(guò)編譯的,雖然obj存儲(chǔ)的是一個(gè)整形,但是如果不進(jìn)行類型轉(zhuǎn)換的話編輯器肯定是不會(huì)編譯通過(guò) 的。所以我們就要改成:

C# code

 
object obj = 10;
obj
= (int)obj + 10;

但是這樣就有個(gè)類型安全的問(wèn)題了,假如我類型不是轉(zhuǎn)換成int,而是string,那么編譯器一樣可以編譯 通過(guò),但是運(yùn)行時(shí)就會(huì)拋出異常: 

C# code

 
object obj = 10;
obj
= (string)obj + 10;
/*
Unhandled Exception: System.InvalidCastException: Unable to cast object of type
'System.Int32' to type 'System.String'.

*/

 由此可見(jiàn),你要使上面代碼正確運(yùn)行,你必須得正確的進(jìn)行類型的顯式轉(zhuǎn)換,就僅僅因?yàn)椴贿@樣做的話,編譯器不 讓你通過(guò)而已。為了解決這個(gè)問(wèn)題,dynamic由此產(chǎn)生。它告訴編譯器:“哥說(shuō)啥就是啥,你甭跟我廢話”。見(jiàn)下例:

C# code

 
dynamic dyn = 10;
dyn
= dyn + 10;
Console.WriteLine(dyn);

dyn
= 10.02;
dyn
= dyn + 10;
Console.WriteLine(dyn);

dyn
= "ojlovecd";
dyn
= dyn + 10;
Console.WriteLine(dyn);

 這是object和dynamic的其中一個(gè)不同。它告訴編譯器對(duì)象的類型只有在運(yùn)行時(shí)才知道,編譯器就不 會(huì)對(duì)其進(jìn)行干涉。這樣你可以少寫很多代碼。但有一點(diǎn)必須強(qiáng)調(diào)一下:dynamic并沒(méi)有增加或減少危險(xiǎn)。當(dāng)你操作對(duì)象時(shí)要用到的所有類型檢查技巧(例如反 射),在動(dòng)態(tài)對(duì)象中一樣要用到。例如,以下代碼在運(yùn)行時(shí)將會(huì)拋出異常:

C# code

 
dynamic dyn = 10;
dyn
= dyn + DateTime.Now;
Console.WriteLine(dyn);

/*

Unhandled Exception: Microsoft.CSharp.RuntimeBinder.RuntimeBinderException: Oper
ator '+' cannot be applied to operands of type 'int' and 'System.DateTime'
at CallSite.Target(Closure , CallSite , Object , DateTime )
at System.Dynamic.UpdateDelegates.UpdateAndExecute2[T0,T1,TRet](CallSite site
, T0 arg0, T1 arg1)
at ConsoleApplication3.Program.Main(String[] args) in D:/CSharpProj/ConsoleAp
plication3/ConsoleApplication3/Program.cs:line 26


*/


 


二、可選(或默認(rèn))參數(shù)

  貌似這個(gè)特性在C#1.0就已經(jīng)有很多人問(wèn)過(guò)了,但直到4.0才有。現(xiàn)在你可以在方法定義的時(shí)候?yàn)閰?shù)指定一個(gè)默認(rèn)值。調(diào)用方法的時(shí)候既可以像平時(shí)那樣傳 入?yún)?shù),也可以直接跳過(guò)不傳入,這樣的話,就使用默認(rèn)值傳到方法里。例如: 

C# code

 
static void Main(string[] args)
{
TestMethod();
TestMethod(
3);
}

static void TestMethod(int i = 10)
{
Console.WriteLine(i);
}

  值得注意一點(diǎn)的是,可選參數(shù)必須放在所有參數(shù)的最后。這里就有個(gè)問(wèn)題了,假如我某個(gè)方法有兩個(gè)參數(shù),兩個(gè)都是可選參數(shù),而我調(diào)用的時(shí)候只想傳入第二個(gè)參 數(shù),怎么辦呢?我們來(lái)試試。 

C# code

 

static void Main(string[] args)
{
TestMethod(
"hello");
}

static void TestMethod(int i = 10, string s = "ojlovecd")
{
Console.WriteLine(
"i:{0},s:{1}", i, s);
}

但很可惜,編譯通不過(guò),這個(gè)問(wèn)題,利用下面的新特性就可以解決了。

三、命名參數(shù) 

在之前版本的C# 中,方法定義的參數(shù)順序必須與方法調(diào)用時(shí)的參數(shù)順序一致,即方法Method(int i, string s)調(diào)用時(shí)就必須第一個(gè)傳入int,第二個(gè)傳入string,而現(xiàn)在,這個(gè)規(guī)矩可以被打破了。你可以自己隨便什么順序傳入,這也在一定程度上提高了代碼的 可讀性。例子:

C# code

 

static void Main(string[] args)
{
TestMethod2(s:
"ojlovecd", i: 26);
}

static void TestMethod2(int i, string s)
{
Console.WriteLine(
"i:{0},s:{1}", i, s);
}

這樣一來(lái),上面的那個(gè)問(wèn)題就可以迎刃而解了: 

C# code

 

static void Main(string[] args)
{
TestMethod(s:
"hello");
}

static void TestMethod(int i = 10, string s = "ojlovecd")
{
Console.WriteLine(
"i:{0},s:{1}", i, s);
}

四、提高COM的互 操作性

基于以上三點(diǎn)新特性,COM的互操作性也被提高了。以后不用再寫如下丑陋的代碼: 

C# code

 

var excelApp = new Excel.Application();
// . . .
excelApp.get_Range("A1", "B4").AutoFormat(
Excel.XlRangeAutoFormat.xlRangeAutoFormatTable3,
Type.Missing, Type.Missing, Type.Missing,
Type.Missing, Type.Missing, Type.Missing);

 現(xiàn)在只需這么寫就搞定了: 

C# code

 



excelApp.Range["A1", "B3"].AutoFormat(
Excel.XlRangeAutoFormat.xlRangeAutoFormatClassic2);

 順帶一句,這段代碼用到了另一個(gè)叫做“索引屬性”的新特性,更多關(guān)于這個(gè)特性的信息可以參考http://msdn.microsoft.com/en-us/library/ee310208%28VS.100%29.aspx

這個(gè)特性只能用于COM互操作上,你不能創(chuàng)建自己的索引屬性。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 张掖市| 浮梁县| 泰和县| 太仆寺旗| 宝应县| 岑巩县| 山丹县| 大名县| 平利县| 禹城市| 射阳县| 视频| 克山县| 虞城县| 西青区| 崇明县| 靖宇县| 滁州市| 杭州市| 左权县| 黄大仙区| 杭锦旗| 清涧县| 汕头市| 邯郸市| 浪卡子县| 丰都县| 泌阳县| 潼关县| 日照市| 凤山市| 溧阳市| 平果县| 屏山县| 松滋市| 峨边| 将乐县| 辽源市| 吉首市| 龙江县| 乐至县|