亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

有關c#裝箱和拆箱知識整理

2019-11-17 01:25:56
字體:
來源:轉載
供稿:網友
有關c#裝箱和拆箱知識整理c#裝箱和拆箱知識,裝箱和拆箱是一個抽象的概念。

1、裝箱和拆箱是一個抽象的概念2、裝箱是將值類型轉換為引用類型 ;

拆箱是將引用類型轉換為值類型

利用裝箱和拆箱功能,可通過允許值類型的任何值與Object 類型的值相互轉換,將值類型與引用類型鏈接起來

例如:

復制代碼代碼如下:int val = 100;object obj = val;Console.WriteLine (“對象的值 = {0}", obj);這是一個裝箱的過程,是將值類型轉換為引用類型的過程復制代碼代碼如下:int val = 100;object obj = val;int num = (int) obj;Console.WriteLine ("num: {0}", num);

這是一個拆箱的過程,是將值類型轉換為引用類型,再由引用類型轉換為值類型的過程

注:被裝過箱的對象才能被拆箱3、.NET中,數據類型劃分為值類型和引用(不等同于C++的指針)類型,與此對應,內存分配被分成了兩種方式,一為棧,二為堆(注意:是托管堆)值類型只會在棧中分配。引用類型分配內存與托管堆。托管堆對應于垃圾回收。

4:裝箱/拆箱是什么?裝箱:用于在垃圾回收堆中存儲值類型。裝箱是值類型到 object 類型或到此值類型所實現的任何接口類型的隱式轉換。拆箱:從 object 類型到值類型或從接口類型到實現該接口的值類型的顯式轉換。

5:為何需要裝箱?(為何要將值類型轉為引用類型?)一種最普通的場景是,調用一個含類型為Object的參數的方法,該Object可支持任意為型,以便通用。當你需要將一個值類型(如Int32)傳入時,需要裝箱。另一種用法是,一個非泛型的容器,同樣是為了保證通用,而將元素類型定義為Object。于是,要將值類型數據加入容器時,需要裝箱。

6:裝箱/拆箱的內部操作

裝箱對值類型在堆中分配一個對象實例,并將該值復制到新的對象中。按三步進行。

新分配托管堆內存(大小為值類型實例大小加上一個方法表指針和一個SyncBlockIndex)。將值類型的實例字段拷貝到新分配的內存中。返回托管堆中新分配對象的地址。這個地址就是一個指向對象的引用了。有人這樣理解:如果將Int32裝箱,返回的地址,指向的就是一個Int32。我認為也不是不能這樣理解,但這確實又有問題,一來它不全面,二來指向Int32并沒說出它的實質(在托管堆中)。

拆箱檢查對象實例,確保它是給定值類型的一個裝箱值。將該值從實例復制到值類型變量中。有書上講,拆箱只是獲取引用對象中指向值類型部分的指針,而內容拷貝則是賦值語句之觸發。我覺得這并不要緊。最關鍵的是檢查對象實例的本質,拆箱和裝箱的類型必需匹配,這一點上,在IL層上,看不出原理何在,我的猜測,或許是調用了類似GetType之類的方法來取出類型進行匹配(因為需要嚴格匹配)。

7:裝箱/拆箱對執行效率的影響

顯然,從原理上可以看出,裝箱時,生成的是全新的引用對象,這會有時間損耗,也就是造成效率降低。那該如何做呢?首先,應該盡量避免裝箱。 www.jbxue.com比如上例2的兩種情況,都可以避免,在第一種情況下,可以通過重載函數來避免。第二種情況,則可以通過泛型來避免。當然,凡事并不能絕對,假設你想改造的代碼為第三方程序集,你無法更改,那你只能是裝箱了。對于裝箱/拆箱代碼的優化,由于C#中對裝箱和拆箱都是隱式的,所以,根本的方法是對代碼進行分析,而分析最直接的方式是了解原理結何查看反編譯的IL代碼。

比如:在循環體中可能存在多余的裝箱,你可以簡單采用提前裝箱方式進行優化。

8:對裝箱/拆箱更進一步的了解

裝箱/拆箱并不如上面所講那么簡單明了

比如:裝箱時,變為引用對象,會多出一個方法表指針,這會有何用處呢?

我們可以通過示例來進一步探討。

舉個例子:

復制代碼代碼如下:Struct A : ICloneable{public Int32 x;public override String ToString() {return String.Format(”{0}”,x);}public object Clone() {return MemberwiseClone();}} // www.jbxue.comstatic void main(){A a;a.x = 100;Console.WriteLine(a.ToString());Console.WriteLine(a.GetType());A a2 = (A)a.Clone();ICloneable c = a2;Ojbect o = c.Clone();}

a.ToString()。編譯器發現A重寫了ToString方法,會直接調用ToString的指令。因為A是值類型,編譯器不會出現多態行為。因此,直接調用,不裝箱。(注:ToString是A的基類System.ValueType的方法)a.GetType(),GetType是繼承于System.ValueType的方法,要調用它,需要一個方法表指針,于是a將被裝箱,從而生成方法表指針,調用基類的System.ValueType。(補一句,所有的值類型都是繼承于System.ValueType的)。a.Clone(),因為A實現了Clone方法,所以無需裝箱。ICloneable轉型:當a2為轉為接口類型時,必須裝箱,因為接口是一種引用類型。c.Clone()。無需裝箱,在托管堆中對上一步已裝箱的對象進行調用。附:其實上面的基于一個根本的原理,因為未裝箱的值類型沒有方法表指針,所以,不能通過值類型來調用其上繼承的虛方法。另外,接口類型是一個引用類型。對此,我的理解,該方法表指針類似C++的虛函數表指針,它是用來實現引用對象的多態機制的重要依據。

9:如何更改已裝箱的對象

對于已裝箱的對象,因為無法直接調用其指定方法,所以必須先拆箱,再調用方法,但再次拆箱,會生成新的棧實例,而無法修改裝箱對象。有點暈吧,感覺在說繞口令。還是舉個例子來說:(在上例中追加change方法)

復制代碼代碼如下:public void Change(Int32 x) {this.x = x;}

調用:

復制代碼代碼如下:A a = new A();a.x = 100;Object o = a; //裝箱成o,下面,想改變o的值((A)o).Change(200); //改掉了嗎?沒改掉沒改掉的原因是o在拆箱時,生成的是臨時的棧實例A,所以,改動是基于臨時A的,并未改到裝箱對象。

(附:在托管C++中,允許直接取加拆箱時第一步得到的實例引用,而直接更改,但C#不行。)那該如何是好?嗯,通過接口方式,可以達到相同的效果。實現如下:

復制代碼代碼如下:interface IChange {void Change(Int32 x);}struct A : IChange {…}

調用:

復制代碼代碼如下:((IChange)o).Change(200);//改掉了嗎?改掉了為啥現在可以改?

在將o轉型為IChange時,這里不會進行再次裝箱,當然更不會拆箱,因為o已經是引用類型,再因為它是IChange類型,所以可以直接調用Change,于是,更改的也就是已裝箱對象中的字段了,達到期望的效果。

10、將值類型轉換為引用類型,需要進行裝箱操作(boxing):

首先從托管堆中為新生成的引用對象分配內存然后將值類型的數據拷貝到剛剛分配的內存中返回托管堆中新分配對象的地址可以看出,進行一次裝箱要進行分配內存和拷貝數據這兩項比較影響性能的操作。

將引用類型轉換為值類型,需要進行拆箱操作(unboxing):

首先獲取托管堆中屬于值類型那部分字段的地址,這一步是嚴格意義上的拆箱。將引用對象中的值拷貝到位于線程堆棧上的值類型實例中。經過這2步,可以認為是同boxing是互反操作。嚴格意義上的拆箱,并不影響性能,但伴隨這之后的拷貝數據的操作就會同boxing操作中一樣影響性能。

11、

NET的所有類型都是由基類System.Object繼承過來的,包括最常用的基礎類型:int, byte, short,bool等等,就是說所有的事物都是對象。

如果申明這些類型得時候都在堆(HEAP)中分配內存,會造成極低的效率!(個中原因以及關于堆和棧得區別會在另一篇里單獨得說說!).NET如何解決這個問題得了?正是通過將類型分成值型(value)和引用型(regerencetype),

C#中定義的值類型和引用類型

值類型:原類型(Sbyte、Byte、Short、Ushort、Int、Uint、Long、Ulong、Char、Float、Double、Bool、Decimal)、枚舉(enum)、結構(struct)引用類型:類、數組、接口、委托、字符串等值型就是在棧中分配內存,在申明的同時就初始化,以確保數據不為NULL;引用型是在堆中分配內存,初始化為null,引用型是需要GARBAGE COLLECTION來回收內存的,值型不用,超出了作用范圍,系統就會自動釋放!下面就來說裝箱和拆箱的定義!裝箱就是隱式的將一個值型轉換為引用型對象。比如:

復制代碼代碼如下:int i=0;Syste.Object obj=i;這個過程就是裝箱!就是將i裝箱!拆箱就是將一個引用型對象轉換成任意值型!比如:復制代碼代碼如下:int i=0;System.Object obj=i;int j=(int)obj;這個過程前2句是將i裝箱,后一句是將obj拆箱!
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久亚洲精品小早川怜子66| 精品亚洲永久免费精品| 黑人巨大精品欧美一区免费视频| 色综合天天综合网国产成人网| 亚洲国产97在线精品一区| 色中色综合影院手机版在线观看| 中文字幕一精品亚洲无线一区| 欧美电影《睫毛膏》| 亚洲日本欧美日韩高观看| 中日韩美女免费视频网址在线观看| 欧美一级免费视频| 福利一区福利二区微拍刺激| 精品久久久久久久久久久久久久| 成人激情视频小说免费下载| 精品福利在线看| 亚洲一级片在线看| zzijzzij亚洲日本成熟少妇| 久久精品视频中文字幕| 国产精品一区二区久久久久| 91精品国产乱码久久久久久蜜臀| 91视频国产高清| 69av成年福利视频| 国产主播喷水一区二区| 国产精品久久久久久久7电影| 久久久欧美一区二区| 日本欧美国产在线| 久久亚洲精品中文字幕冲田杏梨| 色午夜这里只有精品| 亚洲最大在线视频| 久久久日本电影| 国产美女久久精品| 久久亚洲国产精品| 欧美专区国产专区| 性色av香蕉一区二区| 操日韩av在线电影| 97视频在线观看免费| 国模精品系列视频| 亚洲一区二区三区久久| 国产成人avxxxxx在线看| 国产亚洲精品日韩| 欧美黑人又粗大| 欧美精品videos| 精品国产一区二区三区四区在线观看| 欧美www在线| 久久精品91久久久久久再现| 日日噜噜噜夜夜爽亚洲精品| 国产精品久久久久久搜索| 91久久嫩草影院一区二区| 精品毛片三在线观看| 成人日韩在线电影| 中文亚洲视频在线| 欧美激情视频在线免费观看 欧美视频免费一| 清纯唯美亚洲综合| 亚洲性xxxx| 欧美成人精品一区二区三区| 91情侣偷在线精品国产| 久久精品国产96久久久香蕉| 亚洲成人性视频| 日韩视频免费中文字幕| 欧美日韩国产区| 日韩精品在线观| 一区二区三区四区精品| 日韩精品免费在线视频观看| 456国产精品| 精品亚洲国产成av人片传媒| 精品日韩中文字幕| 欧美久久久精品| 26uuu久久噜噜噜噜| 在线精品国产成人综合| 亚洲国产精品久久久久久| 久久久久亚洲精品| 亚洲欧美成人一区二区在线电影| 欧美成人一二三| 九九精品视频在线观看| 久久成人18免费网站| 国产精品爽爽爽爽爽爽在线观看| 在线精品播放av| 久久精品国产v日韩v亚洲| 久久久噜噜噜久久| 亚洲成色999久久网站| 亚洲一区二区三区视频播放| 久久精品国产电影| 欧美中文字幕精品| 亚洲日本中文字幕| 成人免费福利在线| 国产精品视频成人| 91啪国产在线| 欧美亚洲一级片| 欧美专区在线视频| 日韩久久精品电影| 欧美激情综合亚洲一二区| 日韩高清有码在线| 欧美视频二区36p| 国产国语刺激对白av不卡| 国产日韩精品视频| 亚洲国产精品99久久| 国产一区二区三区网站| 久久网福利资源网站| 日韩视频一区在线| 亚洲视频网站在线观看| 欧美激情视频网址| 亚洲精品按摩视频| 欧美影院在线播放| 98精品国产高清在线xxxx天堂| 欧美国产日韩中文字幕在线| 日韩精品免费一线在线观看| 欧美日韩性生活视频| 欧美综合一区第一页| 久久久久久久久久久国产| 国产精品露脸自拍| 欧美在线视频一区二区| 亚洲自拍偷拍色图| 成人国内精品久久久久一区| 成人做爰www免费看视频网站| 中文字幕无线精品亚洲乱码一区| 欧美日韩在线视频观看| 国产精品免费久久久久久| 欧美国产激情18| 日韩在线一区二区三区免费视频| 亚洲欧美激情一区| 欧美激情视频一区二区| 精品无人区乱码1区2区3区在线| 日韩精品中文字幕视频在线| 成人黄色av播放免费| 97成人精品区在线播放| 日韩成人中文字幕在线观看| 亚洲视频777| 国产精品视频99| 亚洲精品小视频| 亚洲视频综合网| 亚洲电影免费观看高清完整版| 欧美日韩国产中字| 亚洲国产精品久久精品怡红院| 欧美天天综合色影久久精品| 亚洲欧美视频在线| 亚洲精品久久久久久久久久久久| 亚洲福利视频免费观看| 精品magnet| 日韩免费黄色av| 日韩中文字幕在线免费观看| 日本国产一区二区三区| 疯狂蹂躏欧美一区二区精品| 午夜精品理论片| 成人免费淫片aa视频免费| 欧美黄色三级网站| 日韩av在线播放资源| 69国产精品成人在线播放| 欧美老少配视频| 一区二区三区黄色| 91豆花精品一区| 日韩视频精品在线| 黄网站色欧美视频| 亚洲男女自偷自拍图片另类| 中文字幕自拍vr一区二区三区| 亚洲国产中文字幕久久网| 亚洲美女av网站| 亚洲黄色av网站| 国产精品第三页| 精品毛片三在线观看| 久久亚洲私人国产精品va| 精品日本高清在线播放| 美女国内精品自产拍在线播放| 亚洲精品美女视频| 日本久久中文字幕|