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

醬壇子

專注C++技術 在這里寫下自己的學習心得 感悟 和大家討論 共同進步(歡迎批評!!!)

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

公告

王一偉 湖南商學院畢業 電子信息工程專業

常用鏈接

留言簿(19)

我參與的團隊

搜索

  •  

積分與排名

  • 積分 - 389904
  • 排名 - 64

最新隨筆

最新評論

閱讀排行榜

評論排行榜

關于gcnew?? (轉)


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

  1.???? gcnew返回的是一個句柄(Handle),而new返回的是實際的內存地址.
  2.???? gcnew創建的對象由虛擬機托管,而new創建的對象必須自己來管理和釋放.
?
  當然,從程序員的角度來說,管它是句柄還是什么其他的東西,總跑不掉是對某塊內存地址的引用,實際上我們都可以理解成指針.下面我們就寫一段代碼來測試一下好了.
?
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;
}
?
  我把調試的時候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]
?
?
?  我們先看分配內存這部分的代碼
?
  1.調用new方式分配
int* pInt = new int;
0000004c? mov???????? ecx,4
00000051? call??????? dword ptr ds:[03B51554h]

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

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

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

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

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

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

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

  這個也相對簡單,它對應vm里面的一個函數:
void? CallFinalizer(Thread* FinalizerThread, Object* fobj)

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

只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   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>
            久久久久久网| 香蕉久久精品日日躁夜夜躁| 亚洲自啪免费| 夜夜嗨一区二区| 久久亚洲国产精品一区二区| 国产一区av在线| 艳女tv在线观看国产一区| 欧美大尺度在线| 久久久精品999| 亚洲国产精品一区| 亚洲第一精品夜夜躁人人躁| 亚洲欧美日韩系列| 黑人巨大精品欧美黑白配亚洲| 欧美一区二区三区精品电影| 欧美一区=区| 亚洲国产精品专区久久| 亚洲午夜国产一区99re久久 | 亚洲精品网址在线观看| 欧美日韩国产麻豆| 午夜欧美电影在线观看| 欧美一区二区三区的| 国产性猛交xxxx免费看久久| 亚洲电影在线看| 国产精品久久久久久久app| 欧美在线观看天堂一区二区三区| 久久九九精品99国产精品| 国产日韩欧美在线观看| 久久婷婷色综合| 国产精品国产三级国产aⅴ入口| 久久久www成人免费毛片麻豆| 欧美极品aⅴ影院| 久久免费视频在线观看| 欧美视频在线观看视频极品| 久久综合久久久| 久久久久久亚洲精品不卡4k岛国| 亚洲私拍自拍| 亚洲精品视频免费在线观看| 亚洲免费小视频| 影音先锋在线一区| 亚洲制服丝袜在线| 136国产福利精品导航| 午夜宅男欧美| 香蕉久久国产| 国产精品入口| 亚洲桃花岛网站| 99这里只有精品| 欧美—级a级欧美特级ar全黄| 麻豆国产va免费精品高清在线| 欧美激情精品久久久久久变态| 久久免费视频在线观看| 一区二区三区在线看| 久久se精品一区二区| 欧美不卡高清| 99国产精品久久久久久久| 亚洲午夜精品国产| 久久免费的精品国产v∧| 毛片基地黄久久久久久天堂| 影音先锋亚洲精品| 欧美成人免费大片| 亚洲男人av电影| 免费久久99精品国产自在现线| 亚洲嫩草精品久久| 亚洲一区二区欧美| 久久久久久夜| 亚洲欧美日韩精品久久久| 久久久国产午夜精品| 亚洲欧美变态国产另类| 一个色综合av| 亚洲免费在线视频| 国产精品视频99| 亚洲欧美日本国产有色| 午夜精品亚洲一区二区三区嫩草| 另类专区欧美制服同性| 欧美a级一区二区| 久久在线视频在线| 国产精品户外野外| 亚洲亚洲精品三区日韩精品在线视频| 99国产精品99久久久久久粉嫩| 欧美wwwwww| 你懂的视频欧美| 激情综合视频| 亚洲精品一区久久久久久| 亚洲国产另类精品专区| 久久天天躁狠狠躁夜夜爽蜜月| 亚洲福利视频免费观看| 亚洲大胆女人| 欧美日韩成人免费| 亚洲免费一在线| 亚洲国产小视频在线观看| 亚洲中无吗在线| 国产精品呻吟| 亚洲自拍啪啪| 欧美77777| 9色精品在线| 亚洲精品视频在线播放| 亚洲国产成人久久| 欧美精品二区| 久久精品国产综合精品| 亚洲精品网站在线播放gif| 久久综合999| 午夜精品福利视频| 欧美色中文字幕| 性伦欧美刺激片在线观看| 亚洲激情电影在线| 国产精品久久久久久久久久妞妞| 久久亚洲精品一区二区| 亚洲无线观看| 葵司免费一区二区三区四区五区| 亚洲电影免费在线观看| 久久国产主播精品| 一区二区三区精品| 99国产精品99久久久久久| 毛片基地黄久久久久久天堂| 欧美一区二区免费| 亚洲视频网站在线观看| 国产视频在线一区二区| 国产精品成人一区二区三区夜夜夜| 亚洲精品一区二区三区婷婷月| 欧美激情性爽国产精品17p| 久久久久久成人| 亚洲专区一区| 亚洲欧美日韩国产| 久久精品一区蜜桃臀影院| 久久久国产亚洲精品| 中文在线资源观看视频网站免费不卡| 亚洲电影在线观看| 亚洲电影免费观看高清完整版在线观看 | 亚洲影视在线播放| 亚洲一区视频| 久久福利精品| 老牛影视一区二区三区| 国产主播喷水一区二区| 国产精品美女在线观看| 国产精品久久久久久五月尺| 国产精品xxxav免费视频| 国产一区二区剧情av在线| 国精品一区二区三区| 亚洲国产精品欧美一二99| 国产伦精品一区二区三区免费迷| 美女精品视频一区| 欧美国产专区| 欧美视频在线不卡| 国内精品久久久| 在线观看三级视频欧美| 国产欧美午夜| 国产精品久久久一本精品| 亚洲高清一区二区三区| 亚洲欧洲另类国产综合| 亚洲永久在线观看| 欧美成年人网站| 亚洲人成人一区二区三区| 亚洲免费在线看| 欧美专区在线观看| 欧美日韩少妇| 欧美亚洲一区二区三区| 午夜精品视频在线观看一区二区 | 一区二区三区**美女毛片| 原创国产精品91| 欧美成人精品1314www| 国产精品99久久久久久www| 欧美精品999| 国产精品一区二区男女羞羞无遮挡| 亚洲欧洲在线免费| 久久精品一区二区| 亚洲欧美第一页| 亚洲第一级黄色片| 麻豆精品在线播放| 午夜免费在线观看精品视频| 国产精品久久久久久久浪潮网站| 99热这里只有精品8| 久久久精品性| 葵司免费一区二区三区四区五区| 国产一区二区| 91久久国产综合久久91精品网站| 久久av红桃一区二区小说| 国产裸体写真av一区二区| 先锋a资源在线看亚洲| 免费国产自线拍一欧美视频| 亚洲视频免费看| 欧美精品一区二区视频| 亚洲小视频在线观看| 欧美伊人久久久久久午夜久久久久 | 免费成人黄色| 久久久精品久久久久| 美女尤物久久精品| 99精品国产在热久久下载| 欧美激情性爽国产精品17p| 久久成人免费网| 亚洲日本中文字幕免费在线不卡| 亚洲激情电影在线| 狠狠色狠狠色综合| 日韩亚洲欧美在线观看| 国语对白精品一区二区| 午夜老司机精品| 亚洲欧洲日本一区二区三区| 亚洲一区久久久| 亚洲欧美国产精品桃花| 欧美在线亚洲综合一区| 日韩一级片网址| 欧美国产高潮xxxx1819|