asp.net(C#)函數(shù)對(duì)象參數(shù)傳遞的問(wèn)題
class Program
{
static void Main(string[] args)
{
TestClass objA = new TestClass();
objA.Name = "I am ObjA";
Console.WriteLine(String.Format("In Main:{0}", objA.Name));
TestFun(objA);
Console.WriteLine(String.Format("In Main:{0}", objA.Name));
Console.Read();
}
static void TestFun(TestClass obj)
{
obj.Name = "I am be modified in TestFun";
Console.WriteLine(String.Format("In TestFun:{0}", obj.Name));
}
public class TestClass
{
public string Name { get; set; }
}
}
將對(duì)象objA作為參數(shù)傳遞給函數(shù)TestFun,這時(shí)傳遞的是對(duì)象objA的引用,所以在函數(shù)內(nèi)對(duì)objA的修改會(huì)直接應(yīng)用到這個(gè)對(duì)象本身。在函數(shù)TestFun內(nèi)修改了形參obj的Name屬性,所以在Main中再調(diào)用objA.Name時(shí)這個(gè)屬性值就變?yōu)樵赥estFun中修改后的值了。這一點(diǎn)很好理解,運(yùn)行結(jié)果也就是:

如果我們換一種寫(xiě)法:
class Program
{
static void Main(string[] args)
{
TestClass objA = new TestClass();
objA.Name = "I am ObjA";
Console.WriteLine(String.Format("In Main:{0}", objA.Name));
TestFun(objA);
Console.WriteLine(String.Format("In Main:{0}", objA.Name));
Console.Read();
}
static void TestFun(TestClass obj)
{
TestClass objB = new TestClass();
obj = objB;
obj.Name = "I am ObjB";
Console.WriteLine(String.Format("In TestFun:{0}", obj.Name));
}
public class TestClass
{
public string Name { get; set; }
}
}
那結(jié)果又將如何呢? 在TestFun中新創(chuàng)建了一個(gè)對(duì)象objB,接著將obj指向新創(chuàng)建的對(duì)象objB并對(duì)其的Name屬性賦值,所以在TestFun函數(shù)體里Console.WriteLine的時(shí)候obj.Name應(yīng)該是“I am ObjB”。那在Main里調(diào)用了TestFun(objA)后objA指向的對(duì)象到底做了改變沒(méi)有,它仍舊指向原來(lái)的對(duì)象還是已經(jīng)指向了在TestFun里創(chuàng)建的objB呢?
我的猜測(cè)是這樣的,將objA傳遞給TestFun傳遞的實(shí)際是objA的地址,在調(diào)用TestFun之前的對(duì)應(yīng)關(guān)系是:

objA是個(gè)變量,他本身的地址是000001,它存放的是objA對(duì)象的地址00E001。當(dāng)調(diào)用函數(shù)TestFun(objA)時(shí),由于要將objA作為參數(shù)傳遞給TestFun,所以在
棧中就復(fù)制一個(gè)objA地址的副本,這個(gè)副本的地址為000003,他存放的仍舊是objA對(duì)象的地址00E001,如圖:

所以在TestFun函數(shù)中,一開(kāi)始o(jì)bj指向的還是objA對(duì)象。當(dāng)在TestFun中創(chuàng)建了一個(gè)對(duì)象objB后,內(nèi)存模型變?yōu)椋?

TestFun中執(zhí)行“obj=objB”后,obj指向objB對(duì)象,如下圖:

所以執(zhí)行完TestFun函數(shù)后,Main函數(shù)中objA仍舊指向原來(lái)的objA對(duì)象,故運(yùn)行結(jié)果如下:

注:本文中的內(nèi)存模型僅是個(gè)人猜測(cè),肯定有不正確或者不嚴(yán)謹(jǐn)?shù)牡胤?,希望不要誤導(dǎo)大家,也歡迎指正。
相關(guān)文章
asp.net下將純真IP數(shù)據(jù)導(dǎo)入數(shù)據(jù)庫(kù)中的代碼
純真IP數(shù)據(jù)庫(kù)包含最新的IP信息,通過(guò)IP我們可以查詢?cè)L問(wèn)者的來(lái)路,地理位置!但下載下來(lái)的IP數(shù)據(jù)無(wú)法被我們直接調(diào)用,所以我們需要編寫(xiě)代碼將IP寫(xiě)入到數(shù)據(jù)庫(kù)中供我們使用!2011-01-01
.NET中利用js讓子窗體向父頁(yè)面?zhèn)髦档膶?shí)現(xiàn)方法
.NET中利用js讓子窗體向父頁(yè)面?zhèn)髦档膶?shí)現(xiàn)方法,需要的朋友可以參考一下2013-02-02
ASP.NET Core3.1 Ocelot路由的實(shí)現(xiàn)
這篇文章主要介紹了ASP.NET Core3.1 Ocelot路由的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-11-11
.Net Core配置與自動(dòng)更新的實(shí)現(xiàn)方法
下面小編就為大家分享一篇.Net Core配置與自動(dòng)更新的實(shí)現(xiàn)方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2017-12-12
使用FlashPaper在線轉(zhuǎn)換.doc為.swf
Flashpaper的使用相信大多數(shù)人都知道,這里的Demo是用于在線轉(zhuǎn)換 .doc文件轉(zhuǎn)換為 .swf的flash文件。2011-02-02
ASP.NET中實(shí)現(xiàn)獲取調(diào)用方法名
這篇文章主要介紹了ASP.NET中實(shí)現(xiàn)獲取調(diào)用方法名的技巧,較為詳細(xì)的講述了相關(guān)的命名空間的調(diào)用及語(yǔ)句執(zhí)行順序,具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2014-12-12
把jQuery的each(callback)方法移植到c#中
jQuery中使用each(callback)方法可以很方便的遍歷集合,如2008-03-03

