

























2011-10-14 11:32 澜心 阅读(611) 评论() 收藏 举报
下面是一段简单的C++代码,分下一下new操作符究竟干了一些什么。
在new的地方,我们按f11跟踪进去。new是封装malloc,按照对象的大小申请内存。我们看到size是8,正好等于person中2个int的大小。
那malloc又做了些什么操作呢。调用了 dbgmalloc.c 和dbgheap.c.
extern "C" void * __cdecl _nh_malloc_dbg (
没有深究,有时间补上,有研究的童鞋请赐教
参考文章:http://blog.csdn.net/hejinjing_tom_com/article/details/4059711
我们知道new操作要调用对应的构造函数,可是我们在new操作的代码中并没有看到调用构造函数的任何代码,我们被书忽悠了?
那构造函数又是什么时候调用的呢。
请参考
点击debug菜单window中的disassembly,查看汇编代码,很容易找到如下代码
Person * p= new Person(); 00171860 push 28h 00171862 call operator new (17131Bh) 00171867 add esp,4 0017186A mov dword ptr [ebp-1A0h],eax 00171870 mov dword ptr [ebp-4],1 00171877 cmp dword ptr [ebp-1A0h],0 0017187E je test+103h (171893h) 00171880 mov ecx,dword ptr [ebp-1A0h] 00171886 call Person::Person (1713B6h) 0017188B mov dword ptr [ebp-1CCh],eax 00171891 jmp test+10Dh (17189Dh) 00171893 mov dword ptr [ebp-1CCh],0 0017189D mov eax,dword ptr [ebp-1CCh] 001718A3 mov dword ptr [ebp-1ACh],eax 001718A9 mov dword ptr [ebp-4],0FFFFFFFFh 001718B0 mov ecx,dword ptr [ebp-1ACh] 001718B6 mov dword ptr [ebp-20h],ecx p->name = "44";
对比C++代码,在 Person * p= new Person(); 和p->name = "44"中间的应该就是new运算符对应的汇编。
对类a的构造函数的调用,是编译器偷偷在你的函数里插入的,当时的情况就是如此。delete的情况也是一摸一样。
我们分析对构造函数的调用应该是编译器插入的。 至于怎么插入的,现在还不太明白。参考文章:http://hi.baidu.com/linx214/blog/item/62251ace1f970e35f8dc6116.html
这个没有找到原帖,抱歉。
子类是怎样调用父类的成员函数的 http://blog.csdn.net/wishfly/article/details/5030381
原文地址:
http://campolake.iteye.com/blog/1195685此内容由惯性聚合(RSS阅读器)自动聚合整理,仅供阅读参考。 原文来自 — 版权归原作者所有。