青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

醬壇子

專注C++技術(shù) 在這里寫下自己的學(xué)習(xí)心得 感悟 和大家討論 共同進(jìn)步(歡迎批評(píng)!!!)

  C++博客 :: 首頁 :: 聯(lián)系 :: 聚合  :: 管理
  66 Posts :: 16 Stories :: 236 Comments :: 0 Trackbacks

公告

王一偉 湖南商學(xué)院畢業(yè) 電子信息工程專業(yè)

常用鏈接

留言簿(19)

我參與的團(tuán)隊(duì)

搜索

  •  

積分與排名

  • 積分 - 389615
  • 排名 - 64

最新隨筆

最新評(píng)論

閱讀排行榜

評(píng)論排行榜

關(guān)于gcnew?? (轉(zhuǎn))


C++/CLI中使用gcnew關(guān)鍵字表示在托管堆上分配內(nèi)存,并且為了與以前的指針區(qū)分,用^來替換* ,就語義上來說他們的區(qū)別大致如下:

  1.???? gcnew返回的是一個(gè)句柄(Handle),而new返回的是實(shí)際的內(nèi)存地址.
  2.???? gcnew創(chuàng)建的對(duì)象由虛擬機(jī)托管,而new創(chuàng)建的對(duì)象必須自己來管理和釋放.
?
  當(dāng)然,從程序員的角度來說,管它是句柄還是什么其他的東西,總跑不掉是對(duì)某塊內(nèi)存地址的引用,實(shí)際上我們都可以理解成指針.下面我們就寫一段代碼來測試一下好了.
?
using namespace System;
?
ref class Foo
{
public:
??? Foo()
??? {
?????? System::Console::WriteLine("Foo::Foo");
??? }
??? ~Foo()
??? {
?????? System::Console::WriteLine("Foo::~Foo");
??? }
public:
??? int m_iValue;
};
?
int _tmain()
{
??? int* pInt = new int;
??? int^ rInt = gcnew int;
??? Foo^ rFoo = gcnew Foo;
?
??? delete rFoo;
??? delete rInt;
??? delete pInt;
}
?
  我把調(diào)試的時(shí)候JIT編譯的匯編代碼擇錄了部分如下顯示(請注意紅色部分):

??? int* pInt = new int;
0000004c? mov???????? ecx,4
00000051? call??????? dword ptr ds:[03B51554h]
00000057? mov???????? esi,eax
00000059? mov???????? dword ptr [esp+18h],esi
??? int^ rInt = gcnew int;
0000005d? mov???????? ecx,788EF9D8h
00000062? call??????? FCFAF66C
00000067? mov???????? esi,eax
00000069? mov???????? dword ptr [esi+4],0
00000070? mov???????? edi,esi
??? Foo^ rFoo = gcnew Foo;
00000072? mov???????? ecx,3B51768h
00000077? call??????? FCFAF66C
0000007c? mov???????? esi,eax
0000007e? mov???????? ecx,esi
00000080? call??????? dword ptr ds:[03B517ACh]
00000086? mov???????? dword ptr [esp+1Ch],esi
?
??? delete rFoo;
0000008a? mov???????? ebx,dword ptr [esp+1Ch]
0000008e? test??????? ebx,ebx
00000090? je????????? 000000A4
00000092? mov???????? ecx,ebx
00000094? call??????? dword ptr ds:[03FD0028h]
0000009a? mov???????? dword ptr [esp+14h],0
000000a2? jmp???????? 000000AC
000000a4? mov???????? dword ptr [esp+14h],0
??? delete rInt;
000000ac? mov???????? edx,edi
000000ae? mov???????? ecx,788F747Ch
000000b3? call??????? FC8D20FD
000000b8? mov???????? ebp,eax
000000ba? test??????? ebp,ebp
000000bc? je????????? 000000D0
000000be? mov???????? ecx,ebp
000000c0? call??????? dword ptr ds:[03FD0020h]
000000c6? mov???????? dword ptr [esp+10h],0
000000ce? jmp???????? 000000D8
000000d0? mov???????? dword ptr [esp+10h],0
??? delete pInt;
000000d8? mov???????? ecx,dword ptr [esp+18h]
000000dc? call??????? dword ptr ds:[03B51540h]
?
?
?  我們先看分配內(nèi)存這部分的代碼
?
  1.調(diào)用new方式分配
int* pInt = new int;
0000004c? mov???????? ecx,4
00000051? call??????? dword ptr ds:[03B51554h]

  可以看到,和以前在vc6中一樣,分配內(nèi)存的步驟如下:
  1.? 首先把sizeof(int) = 4 放到ecx中
  2.? 調(diào)用operator new 去分配4個(gè)字節(jié)
  3.? 調(diào)用構(gòu)造函數(shù)等等......(這里不是我們的重點(diǎn))

  成功分配后,會(huì)把返回地址放在eax中。
?
  2.調(diào)用gcnew方式分配
??? int^ rInt = gcnew int;
0000005d? mov???????? ecx,788EF9D8h
00000062? call??????? FCFAF66C
。。。
??? Foo^ rFoo = gcnew Foo;
00000072? mov???????? ecx,3B51768h
00000077? call??????? FCFAF66C

  可以看到gcnew也是通過把一個(gè)參數(shù)放到ecx中,然后再調(diào)用一個(gè)函數(shù)來完成分配的操作,顯然0x788EF9D8應(yīng)該是一個(gè)地址,而不可能是一個(gè)數(shù)值。我們可以看到這里gcnew創(chuàng)建兩個(gè)不同類型的變量,調(diào)用的函數(shù)地址卻都是0xFCFAF66C,而存放到ecx中的兩個(gè)地址就不一樣。究竟這幾個(gè)地址代表什么呢?
?
  和new一樣gcnew也是把返回地址放在eax中。我們直接從內(nèi)存窗口看eax指向的內(nèi)存塊好了。Aha,看到了沒有?

  這次的eax = 0x00F73404? 對(duì)應(yīng)的內(nèi)存塊為
?
0x00F73404? d8 f9 8e 78 00 00 00 00 。。。
?
  這個(gè)不就是 mov 到 ecx中的值么?再回憶昨天寫的分析Object對(duì)象布局的文章,可以肯定這個(gè)就是 MethodTable地址了,對(duì)于這個(gè)int來說,后面的4個(gè)字節(jié)對(duì)應(yīng)的就是存放它的RawData,比如如果你初始化為 4 那么內(nèi)存對(duì)應(yīng)的就變化為 d8 f9 8e 79 04 00 00 00
?
  分析清楚存放到ecx中的是 MethodTable指針,我們再分析那個(gè)對(duì)應(yīng)的call函數(shù),從vm的代碼可以看出,有三個(gè)全局函數(shù)用來根據(jù)MethodTable創(chuàng)建對(duì)象,同時(shí)MethodTable本身也提供一個(gè)成員函數(shù)Allocate(),只不過這個(gè)成員函數(shù)也是調(diào)用的下面的函數(shù):

OBJECTREF AllocateObject( MethodTable *pMT )
OBJECTREF AllocateObjectSpecial( MethodTable *pMT )
OBJECTREF FastAllocateObject( MethodTable *pMT )
?
  其中AllocateObject又是調(diào)用AllocateObjectSpecial來完成工作。那么我們調(diào)用的應(yīng)該就是AllocateObject或者FastAllocateObject了。

  在我們的例子里面兩個(gè)call的地址都一樣,但是你如果寫下代碼 double ^ pDouble = gcnew double;這個(gè)時(shí)候的地址是多少?它和int 的一樣么?

  目前我還沒有仔細(xì)去研究這個(gè)地址到底對(duì)應(yīng)的是該類型的MethodTable::Allocate()或是上面的這三個(gè)全局函數(shù),如果對(duì)應(yīng)MethodTable::Allocate(),那么2.0中應(yīng)該有個(gè)MethodTable::FastAllocate()吧,否則應(yīng)該就是對(duì)應(yīng)的全局函數(shù)AllocateObject 以及FastAllocateObject了。過幾天一定要抽空再好好研究一下。
?
  下面看對(duì)應(yīng)的delete函數(shù)。
??? delete pInt;
000000d8? mov???????? ecx,dword ptr [esp+18h]
000000dc? call??????? dword ptr ds:[03B51540h]
?
比較簡單,就是傳入地址,然后調(diào)用operator delete來釋放類存,會(huì)調(diào)用析構(gòu)函數(shù)
?
  對(duì)應(yīng)的,釋放gcnew創(chuàng)建的對(duì)象的代碼如下:
??? delete rInt;
000000ac? mov???????? edx,edi
000000ae? mov???????? ecx,788F747Ch
000000b3? call??????? FC8D20FD

  這個(gè)也相對(duì)簡單,它對(duì)應(yīng)vm里面的一個(gè)函數(shù):
void? CallFinalizer(Thread* FinalizerThread, Object* fobj)

  那么也就是
fobjà edx
FinalizerThread à ecx
Call CallFinalizer
?
  但是,請注意!!!!!!!一個(gè)類包含析構(gòu)函數(shù)和不包含析構(gòu)函數(shù),它對(duì)應(yīng)的delete代碼是不一樣的,這點(diǎn)可以通過匯編代碼比較得到,我這里就不多說了。
posted on 2007-03-20 12:52 @王一偉 閱讀(3019) 評(píng)論(0)  編輯 收藏 引用

只有注冊用戶登錄后才能發(fā)表評(píng)論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            国产精品色网| 亚洲视频一区在线| 欧美aaa级| 久久久久成人网| 久久久久国产精品麻豆ai换脸 | 欧美激情视频给我| 男同欧美伦乱| 欧美三级网址| 国产午夜精品视频免费不卡69堂| 国产视频久久网| 亚洲国产精品一区| 亚洲一区二区av电影| 久久精品国产亚洲一区二区| 免费观看亚洲视频大全| 99视频精品免费观看| 欧美与欧洲交xxxx免费观看 | 久久久久久久尹人综合网亚洲| 欧美一区精品| 免费在线欧美视频| 亚洲精品在线一区二区| 亚洲精品字幕| 久久精品99国产精品日本 | 亚洲一区在线观看视频| 亚洲一区日韩| 欧美一级免费视频| 久久精品在线视频| 欧美国产高清| 欧美日韩专区| 国产欧美一区二区精品婷婷| 国产亚洲欧美aaaa| 亚洲国产精品一区二区三区| 亚洲人成欧美中文字幕| 一区二区欧美在线| 久久精品国产免费| 美乳少妇欧美精品| 日韩亚洲精品电影| 久久国产一区| 亚洲一区二区三区乱码aⅴ蜜桃女 亚洲一区二区三区乱码aⅴ | 亚洲乱码日产精品bd| 亚洲自拍高清| 久久精品人人| 欧美日韩性生活视频| 国产午夜精品久久| 亚洲美女性视频| 亚洲毛片网站| 欧美一区三区二区在线观看| 久久久免费观看视频| 亚洲福利视频免费观看| 99国产精品久久久| 亚洲欧美激情视频| 美女国产一区| 国产视频不卡| 在线中文字幕日韩| 久久亚洲综合色一区二区三区| 亚洲国产一区二区精品专区| 亚洲综合色婷婷| 欧美精品v国产精品v日韩精品 | 一区二区三区免费看| 久久精品一区四区| 国产精品男女猛烈高潮激情 | 久久精品日产第一区二区三区| 亚洲欧洲日本专区| 久久婷婷成人综合色| 国产精品视频一区二区三区| 亚洲精品一区二区三区福利| 久久综合色影院| 亚洲欧美日韩人成在线播放| 欧美国产日本在线| 一区国产精品| 久久精品最新地址| 亚洲欧美精品在线| 欧美色视频一区| 亚洲精品久久久蜜桃| 免费亚洲一区| 日韩视频在线观看国产| 亚洲一区在线看| 久久久999国产| 欧美精品系列| 狠狠色伊人亚洲综合网站色| 亚洲视频在线观看网站| 久久深夜福利免费观看| 一本久道综合久久精品| 久久国产精品电影| 欧美日韩一级视频| 黑丝一区二区三区| 午夜亚洲福利| 亚洲日本黄色| 美脚丝袜一区二区三区在线观看| 久久精品中文字幕一区二区三区 | 亚洲一区二区三区中文字幕在线| 亚洲国产欧美日韩| 欧美精品一区二区三区在线看午夜| 亚洲福利视频网| 欧美成人免费观看| 午夜精品福利在线观看| 欧美午夜精品久久久| 一区国产精品| 久久久久免费视频| 美脚丝袜一区二区三区在线观看| 国产毛片精品视频| 亚洲欧美日韩高清| 亚洲精品欧美日韩| 国产精品九九久久久久久久| 欧美在线高清| 久久久亚洲精品一区二区三区| 亚洲高清久久网| 一区二区三区免费观看| 国产午夜精品久久| 欧美激情亚洲| 欧美四级剧情无删版影片| 午夜精品视频在线观看| 欧美诱惑福利视频| 亚洲美女免费精品视频在线观看| 亚洲精品网站在线播放gif| 欧美性片在线观看| 久久这里只有| 欧美日本高清| 久久青青草原一区二区| 欧美激情第8页| 欧美一级午夜免费电影| 久久久久国产一区二区| 一区二区三区高清在线 | 亚洲欧美激情诱惑| 久久久五月天| 亚洲在线播放电影| 久久亚洲欧美| 亚洲欧美影院| 老司机凹凸av亚洲导航| 亚洲一区二区少妇| 美女免费视频一区| 欧美诱惑福利视频| 欧美日韩国产页| 米奇777在线欧美播放| 国产精品第三页| 欧美激情91| 国内精品嫩模av私拍在线观看| 亚洲精品国产精品久久清纯直播 | 日韩一区二区电影网| 欧美中文字幕不卡| 亚洲精品永久免费| 久久久久久久欧美精品| 亚洲无人区一区| 欧美成人免费网| 久久综合网hezyo| 国产精自产拍久久久久久蜜| 亚洲精品免费在线观看| 91久久久久久久久| 久久久久久久综合狠狠综合| 欧美一区二区高清| 国产精品va在线播放| 亚洲欧洲精品一区二区精品久久久| 国产一区二区三区久久精品| 一区二区av在线| 在线视频中文亚洲| 老司机久久99久久精品播放免费| 欧美精品日韩一本| 麻豆国产精品va在线观看不卡| 欧美性色aⅴ视频一区日韩精品| 亚洲国产精品精华液2区45| 亚洲二区视频在线| 久久久久久久999精品视频| 久久综合激情| 亚洲第一偷拍| 欧美aⅴ99久久黑人专区| 欧美激情视频一区二区三区在线播放| 在线精品观看| 欧美福利视频| 一本色道久久综合精品竹菊| 亚洲在线播放电影| 国产热re99久久6国产精品| 香蕉成人久久| 男女激情久久| 亚洲精品麻豆| 久久久久国产精品一区| 欧美成人蜜桃| 亚洲视屏在线播放| 国产原创一区二区| 另类图片综合电影| 99精品热视频只有精品10| 午夜精品免费视频| 狠狠入ady亚洲精品经典电影| 久久综合久久综合这里只有精品 | 亚洲深夜影院| 国产精品亚洲片夜色在线| 欧美一区二区三区在线视频 | 国产一区二区成人久久免费影院| 午夜日韩在线观看| 欧美sm视频| 中文精品99久久国产香蕉| 国产精品高潮粉嫩av| 欧美在线|欧美| 亚洲欧洲日韩女同| 欧美一区二区三区视频免费播放| 国际精品欧美精品| 欧美激情1区2区3区| 亚洲自啪免费| 亚洲国产精品电影| 久久高清一区| 亚洲桃花岛网站| 亚洲国产成人久久综合一区|