asp.net(c#)ref,out ,params的區(qū)別
更新時(shí)間:2009年12月26日 22:13:03 作者:
C#中有三個(gè)關(guān)鍵字-ref,out ,params,雖然本人不喜歡這三個(gè)關(guān)鍵字,因?yàn)樗鼈円伤破茐拿嫦驅(qū)ο筇匦?。但是既然m$把融入在c#體系中,那么我們就來(lái)認(rèn)識(shí)一下參數(shù)修飾符ref,out ,params吧,還有它們的區(qū)別。
NO.1 params
一個(gè)可以讓方法(函數(shù))的擁有可變參數(shù)的關(guān)鍵字。
原則:在方法聲明中的 params 關(guān)鍵字之后不允許任何其他參數(shù),并且在方法聲明中只允許一個(gè) params 關(guān)鍵字。
示例(拷貝到vs2005中即可用,下面不再說(shuō)明)
public partial class Form1 : Form
{
public static void UseParams(params int[] list)
{
string temp = "";
for (int i = 0; i < list.Length; i++)
temp = temp +" " +list[i].ToString();
MessageBox.Show(temp);
}
public static void UseParams2(params object[] list)
{
string temp = "";
for (int i = 0; i < list.Length; i++)
temp = temp + " " + list[i].ToString();
MessageBox.Show(temp);
}
public Form1()
{
InitializeComponent();
}
private void button1_Click(object sender, EventArgs e)
{
UseParams(1, 2, 3);//看參數(shù)是3個(gè)
UseParams(1, 2); //看參數(shù)是2個(gè),可變吧
UseParams2(1, 'a', "test");
int[] myarray = new int[3] { 10, 11, 12 };
UseParams(myarray); //看也可以是容器類(lèi),可變吧:)
}
}
NO.2 out
這是一個(gè)引用傳遞L。
原則一:當(dāng)一個(gè)方法(函數(shù))在使用out作為參數(shù)時(shí),在方法中(函數(shù))對(duì)out參數(shù)所做的任何更改都將反映在該變量中。
原則二:當(dāng)希望方法返回多個(gè)值時(shí),聲明 out 方法非常有用。使用 out 參數(shù)的方法仍然可以返回一個(gè)值。一個(gè)方法可以有一個(gè)以上的 out 參數(shù)。
原則三:若要使用 out 參數(shù),必須將參數(shù)作為 out 參數(shù)顯式傳遞到方法。out 參數(shù)的值不會(huì)傳遞到 out 參數(shù)。
原則四:不必初始化作為 out 參數(shù)傳遞的變量,因?yàn)閛ut 參數(shù)在進(jìn)入方法(函數(shù))時(shí)后清空自己,使自己變成一個(gè)干凈的參數(shù),也因?yàn)檫@個(gè)原因必須在方法返回之前為 out 參數(shù)賦值(只有地址沒(méi)有值的參數(shù)是不能被.net接受的)。
原則五:屬性不是變量,不能作為 out 參數(shù)傳遞。
原則六:如果兩個(gè)方法的聲明僅在 out 的使用方面不同,則會(huì)發(fā)生重載。不過(guò),無(wú)法定義僅在 ref 和 out 方面不同的重載。例如,以下重載聲明是有效的:
class MyClass
{
public void MyMethod(int i) {i = 10;}
public void MyMethod(out int i) {i = 10;}
}
而以下重載聲明是無(wú)效的:
class MyClass
{
public void MyMethod(out int i) {i = 10;}
public void MyMethod(ref int i) {i = 10;}
}
有關(guān)傳遞數(shù)組的信息,請(qǐng)參見(jiàn)使用 ref 和 out 傳遞數(shù)組。
示例附后
NO.2 ref
ref僅僅是一個(gè)地址?。?!
原則一:當(dāng)一個(gè)方法(函數(shù))在使用ref作為參數(shù)時(shí),在方法中(函數(shù))對(duì)ref參數(shù)所做的任何更改都將反映在該變量中。
原則二:調(diào)用方法時(shí),在方法中對(duì)參數(shù)所做的任何更改都將反映在該變量中。
原則三:若要使用 ref 參數(shù),必須將參數(shù)作為 ref 參數(shù)顯式傳遞到方法。ref 參數(shù)的值可以被傳遞到 ref 參數(shù)。
原則四:ref參數(shù)傳遞的變量必須初始化,因?yàn)閞ef參數(shù)在進(jìn)入方法(函數(shù))時(shí)后還是它自己,它這個(gè)地址指向的還是原來(lái)的值,也因?yàn)檫@個(gè)原因ref參數(shù)也可以在使用它的方法內(nèi)部不操作。
原則六:如果兩種方法的聲明僅在它們對(duì) ref 的使用方面不同,則將出現(xiàn)重載。但是,無(wú)法定義僅在 ref 和 out 方面不同的重載。例如,以下重載聲明是有效的:
class MyClass
{
public void MyMethod(int i) {i = 10;}
public void MyMethod(ref int i) {i = 10;}
}
但以下重載聲明是無(wú)效的:
class MyClass
{
public void MyMethod(out int i) {i = 10;}
public void MyMethod(ref int i) {i = 10;}
}
有關(guān)傳遞數(shù)組的信息,請(qǐng)參見(jiàn)使用 ref 和 out 傳遞數(shù)組。
示例
public static string TestOut(out string i)
{
i = "out b";
return "return value";
}
public static void TestRef(ref string i)
{
//改變參數(shù)
i = "ref b";
}
public static void TestNoRef(string refi)
{
// 不用改變?nèi)魏螙|西,這個(gè)太明顯了
refi = "on c";
}
public Form1()
{
InitializeComponent();
}
private void button1_Click(object sender, EventArgs e)
{
string outi;//不需要初始化
MessageBox.Show(TestOut(out outi));//返回值
//輸出"return value";
MessageBox.Show(outi);//調(diào)用后的out參數(shù)
//輸出"out b";
string refi = "a"; // 必須初始化
TestRef(ref refi); // 調(diào)用參數(shù)
MessageBox.Show(refi);
//輸出"ref b";
TestNoRef(refi);//不使用ref
MessageBox.Show(refi);
//輸出"ref b";
}
一個(gè)可以讓方法(函數(shù))的擁有可變參數(shù)的關(guān)鍵字。
原則:在方法聲明中的 params 關(guān)鍵字之后不允許任何其他參數(shù),并且在方法聲明中只允許一個(gè) params 關(guān)鍵字。
示例(拷貝到vs2005中即可用,下面不再說(shuō)明)
復(fù)制代碼 代碼如下:
public partial class Form1 : Form
{
public static void UseParams(params int[] list)
{
string temp = "";
for (int i = 0; i < list.Length; i++)
temp = temp +" " +list[i].ToString();
MessageBox.Show(temp);
}
public static void UseParams2(params object[] list)
{
string temp = "";
for (int i = 0; i < list.Length; i++)
temp = temp + " " + list[i].ToString();
MessageBox.Show(temp);
}
public Form1()
{
InitializeComponent();
}
private void button1_Click(object sender, EventArgs e)
{
UseParams(1, 2, 3);//看參數(shù)是3個(gè)
UseParams(1, 2); //看參數(shù)是2個(gè),可變吧
UseParams2(1, 'a', "test");
int[] myarray = new int[3] { 10, 11, 12 };
UseParams(myarray); //看也可以是容器類(lèi),可變吧:)
}
}
NO.2 out
這是一個(gè)引用傳遞L。
原則一:當(dāng)一個(gè)方法(函數(shù))在使用out作為參數(shù)時(shí),在方法中(函數(shù))對(duì)out參數(shù)所做的任何更改都將反映在該變量中。
原則二:當(dāng)希望方法返回多個(gè)值時(shí),聲明 out 方法非常有用。使用 out 參數(shù)的方法仍然可以返回一個(gè)值。一個(gè)方法可以有一個(gè)以上的 out 參數(shù)。
原則三:若要使用 out 參數(shù),必須將參數(shù)作為 out 參數(shù)顯式傳遞到方法。out 參數(shù)的值不會(huì)傳遞到 out 參數(shù)。
原則四:不必初始化作為 out 參數(shù)傳遞的變量,因?yàn)閛ut 參數(shù)在進(jìn)入方法(函數(shù))時(shí)后清空自己,使自己變成一個(gè)干凈的參數(shù),也因?yàn)檫@個(gè)原因必須在方法返回之前為 out 參數(shù)賦值(只有地址沒(méi)有值的參數(shù)是不能被.net接受的)。
原則五:屬性不是變量,不能作為 out 參數(shù)傳遞。
原則六:如果兩個(gè)方法的聲明僅在 out 的使用方面不同,則會(huì)發(fā)生重載。不過(guò),無(wú)法定義僅在 ref 和 out 方面不同的重載。例如,以下重載聲明是有效的:
復(fù)制代碼 代碼如下:
class MyClass
{
public void MyMethod(int i) {i = 10;}
public void MyMethod(out int i) {i = 10;}
}
而以下重載聲明是無(wú)效的:
復(fù)制代碼 代碼如下:
class MyClass
{
public void MyMethod(out int i) {i = 10;}
public void MyMethod(ref int i) {i = 10;}
}
有關(guān)傳遞數(shù)組的信息,請(qǐng)參見(jiàn)使用 ref 和 out 傳遞數(shù)組。
示例附后
NO.2 ref
ref僅僅是一個(gè)地址?。?!
原則一:當(dāng)一個(gè)方法(函數(shù))在使用ref作為參數(shù)時(shí),在方法中(函數(shù))對(duì)ref參數(shù)所做的任何更改都將反映在該變量中。
原則二:調(diào)用方法時(shí),在方法中對(duì)參數(shù)所做的任何更改都將反映在該變量中。
原則三:若要使用 ref 參數(shù),必須將參數(shù)作為 ref 參數(shù)顯式傳遞到方法。ref 參數(shù)的值可以被傳遞到 ref 參數(shù)。
原則四:ref參數(shù)傳遞的變量必須初始化,因?yàn)閞ef參數(shù)在進(jìn)入方法(函數(shù))時(shí)后還是它自己,它這個(gè)地址指向的還是原來(lái)的值,也因?yàn)檫@個(gè)原因ref參數(shù)也可以在使用它的方法內(nèi)部不操作。
原則六:如果兩種方法的聲明僅在它們對(duì) ref 的使用方面不同,則將出現(xiàn)重載。但是,無(wú)法定義僅在 ref 和 out 方面不同的重載。例如,以下重載聲明是有效的:
復(fù)制代碼 代碼如下:
class MyClass
{
public void MyMethod(int i) {i = 10;}
public void MyMethod(ref int i) {i = 10;}
}
但以下重載聲明是無(wú)效的:
復(fù)制代碼 代碼如下:
class MyClass
{
public void MyMethod(out int i) {i = 10;}
public void MyMethod(ref int i) {i = 10;}
}
有關(guān)傳遞數(shù)組的信息,請(qǐng)參見(jiàn)使用 ref 和 out 傳遞數(shù)組。
示例
復(fù)制代碼 代碼如下:
public static string TestOut(out string i)
{
i = "out b";
return "return value";
}
public static void TestRef(ref string i)
{
//改變參數(shù)
i = "ref b";
}
public static void TestNoRef(string refi)
{
// 不用改變?nèi)魏螙|西,這個(gè)太明顯了
refi = "on c";
}
public Form1()
{
InitializeComponent();
}
private void button1_Click(object sender, EventArgs e)
{
string outi;//不需要初始化
MessageBox.Show(TestOut(out outi));//返回值
//輸出"return value";
MessageBox.Show(outi);//調(diào)用后的out參數(shù)
//輸出"out b";
string refi = "a"; // 必須初始化
TestRef(ref refi); // 調(diào)用參數(shù)
MessageBox.Show(refi);
//輸出"ref b";
TestNoRef(refi);//不使用ref
MessageBox.Show(refi);
//輸出"ref b";
}
您可能感興趣的文章:
- c# 可變數(shù)目參數(shù)params實(shí)例
- C#中Params的用法
- C#難點(diǎn)逐個(gè)擊破(3):params數(shù)組參數(shù)
- C# 運(yùn)用params修飾符來(lái)實(shí)現(xiàn)變長(zhǎng)參數(shù)傳遞的方法
- 用C#中的params關(guān)鍵字實(shí)現(xiàn)方法形參個(gè)數(shù)可變
- 用C#的params關(guān)鍵字實(shí)現(xiàn)方法形參個(gè)數(shù)可變示例
- c#的params參數(shù)使用示例
- 詳解C#中三個(gè)關(guān)鍵字params,Ref,out
- C# params可變參數(shù)的使用注意詳析
相關(guān)文章
"虛擬路徑"..."映射到另一個(gè)應(yīng)用程序,這是不允許的!
原因: 用戶(hù)控件不能跨虛擬目錄調(diào)用。2008-12-12vb 中的MD5加密在asp.net中的實(shí)現(xiàn)
給定標(biāo)識(shí)哈希類(lèi)型的密碼和字符串,該例程產(chǎn)生一個(gè)適合存儲(chǔ)在配置文件中的哈希密碼,感興趣的朋友可以參考下本文2013-04-04asp.net textbox javascript實(shí)現(xiàn)enter與ctrl+enter互換 文本框發(fā)送消息與換行(類(lèi)似
今天與大家分享一下 asp.net textbox javascript實(shí)現(xiàn)enter與ctrl+enter互換 文本框發(fā)送消息與換行(類(lèi)似于QQ),這個(gè)功能到底怎么實(shí)現(xiàn)?首先聲明以下幾點(diǎn)2012-01-01擴(kuò)展方法ToJSON() and ParseJSON()
AJAX編程經(jīng)常需要Object<=>JSON之間轉(zhuǎn)換,寫(xiě)了二個(gè)擴(kuò)展方法: public static string ToJSON(this object obj) public static T ParseJSON<T>(this string str)2008-03-03值得收藏的asp.net基礎(chǔ)學(xué)習(xí)筆記
這篇文章主要分享了一份值得大家收藏的asp.net基礎(chǔ)學(xué)習(xí)筆記,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-09-09asp.net mvc CodeFirst模式數(shù)據(jù)庫(kù)遷移步驟詳解
這篇文章主要為大家詳細(xì)介紹了asp.net mvc CodeFirst模式數(shù)據(jù)庫(kù)遷移步驟,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-10-10