新聞中心
相比較C++,C#中的值類(lèi)型和引用類(lèi)型很簡(jiǎn)單:所有的基本類(lèi)型、結(jié)構(gòu)(struct)和String屬于值類(lèi)型,其它類(lèi)型(其實(shí)也只剩下class了)都屬于引用類(lèi)型。那么值類(lèi)型和引用類(lèi)型有什么區(qū)別呢?

值類(lèi)型在賦值操作(“=”操作,函數(shù)參數(shù),函數(shù)返回等)的時(shí)候,會(huì)把所有成員變量拷貝一遍給目標(biāo)實(shí)例。
引用類(lèi)型在賦值操作的時(shí)候,只是把實(shí)例的內(nèi)存中的地址賦值給目標(biāo)實(shí)例。
那么這兩者有什么區(qū)別呢?
那就是效率了:
引用類(lèi)型的賦值只要傳遞一個(gè)內(nèi)存地址,傳遞的數(shù)據(jù)量就是一個(gè)32(64位操作系統(tǒng)是64)位整數(shù)。
值類(lèi)型需要傳遞該類(lèi)型所包含的所有數(shù)據(jù)。
比如:
- struct Point
- {
- public int x;
- public int y;
- }
那Point類(lèi)型的實(shí)例在賦值的時(shí)候,要傳遞的數(shù)據(jù)量是兩個(gè)整數(shù)。
如果數(shù)據(jù)量更大的結(jié)構(gòu),每次賦值的時(shí)候都要傳遞一遍所有的成員,那么總的程序運(yùn)行期內(nèi),傳遞的數(shù)據(jù)量就非常可觀了。
怎么解決這種效率問(wèn)題呢?
有兩種方法:
1 使用ref關(guān)鍵字。
2 就是用所謂的Boxing和Unboxing了。
首先,C#中Boxing和Unboxing是針對(duì)值類(lèi)型數(shù)據(jù)而言的。對(duì)引用類(lèi)型來(lái)說(shuō),它本身就是引用類(lèi)型,所以不存在Boxing和Unboxing的概念。
其次,Boxing的操作就是把值類(lèi)型的數(shù)據(jù)賦值到一個(gè)object的引用類(lèi)型實(shí)例中,這個(gè)過(guò)程是值賦值的過(guò)程(就是所以數(shù)據(jù)都copy一遍)。
如:
Point p = new Point{x=10, y=11};
Object o = p;
這個(gè)變量o就是Boxing之后的引用類(lèi)型了。記住一點(diǎn),boxing之后,變量o就跟p無(wú)關(guān)了,它們是兩個(gè)不同類(lèi)型的變量,指向不同的內(nèi)存地址。
***,Unboxing的操作是把這個(gè)object的引用類(lèi)型實(shí)例,以值傳遞的方式賦值給目標(biāo)對(duì)象。
如:
Point p2 = (Point)o;
unboxing之后,p2跟o就無(wú)關(guān)了,它們是兩個(gè)不同類(lèi)型的變量,指向不同的內(nèi)存地址。
也就是說(shuō),Boxing和Unboxing的***用途就是用于數(shù)據(jù)傳遞。
理解Boxing和Unboxing還要與class的類(lèi)型向父類(lèi)/子類(lèi)轉(zhuǎn)換的操作區(qū)別開(kāi)來(lái)(面向?qū)ο笳Z(yǔ)言的繼承機(jī)制)。
將一個(gè)class的實(shí)例轉(zhuǎn)換成它的父類(lèi)或子類(lèi)類(lèi)型,這是類(lèi)的繼承機(jī)制。這種轉(zhuǎn)換其實(shí)只是把實(shí)例的類(lèi)型信息變了下,實(shí)例對(duì)應(yīng)的數(shù)據(jù),內(nèi)存地址都沒(méi)變動(dòng)。轉(zhuǎn)換前后的實(shí)例都是指向同一塊內(nèi)存。
但我們可以把C#中Boxing和Unboxing和class繼承機(jī)制統(tǒng)一起來(lái),用一句話來(lái)概括就是:引用進(jìn),引用出;值進(jìn),值出。
文章題目:C#中Boxing和Unboxing
標(biāo)題URL:http://www.5511xx.com/article/dpepisd.html


咨詢
建站咨詢
