>来自:ZDNet</P>
>标准首部<NEW>由一个特别的操作符new来定义,这个就是我们熟知的placement new。和其他普通的new不同的是,它在括号里多了另外一个参数。比如:
><FONT color=#0066ff>Widget * p = new Widget; <FONT color=#006600>//普通的new</FONT> pi = new (ptr) int; <FONT color=#006600>//placement new</FONT> </FONT></P>9 m# ] B" q+ q# x2 w2 j5 T
>括号里的参数是一个指针,它指向一个内存缓冲器,placement new将在这个缓冲器上分配一个对象。Placement new的返回值是这个被构造对象的地址。在对时间要求非常高的应用程序中,placement new是非常有用的,因为这些程序分配的时间是确定的,它们必须长时间的运行并要进行垃圾回收。</P>
>在一些时候placement new的使用方法和其他普通的new不同。这里提供了它的使用方法。</P>
>确定被placement new使用的缓存区的内存队列已经准备好,使用普通的new来分配它:</P>% k3 l% H7 h \7 o" @6 V$ e! a" Z
><FONT color=#0066ff>class Task {/*..*/};
>在刚才已分配的缓存区调用placement new来构造一个对象。</P>/ m2 Y$ [- G* P7 G$ z
><FONT color=#0066ff>Task *ptask = new(buff) Task</FONT></P>
>按照普通方式利用分配的对象:</P>
><FONT color=#0066ff>ptask->suspend();+ {! D! A. s! |$ M
>一旦你使用完这个对象,你必须调用它的析构函数来毁灭它。按照下面的方式调用析构函数:</P>
><FONT color=#0066ff>ptask->~Task();</FONT> <FONT color=#006600>//调用外在的析构函数</FONT></P>
>你可以反复利用缓存并给它分配一个新的对象(重复步骤2,3,4)如果你不打算再度使用这个缓存,你可以象这样释放它:</P>
><FONT color=#0066ff>delete [] buff;</FONT></P>! u* J& |' X! e, N2 v ]- v7 X. j
>如果跳过任何步骤就可能导致运行时间的崩溃,内存不够,以及其他的意想不到的状况。如果你需要使用placement new,请按照上面步骤一步步的执行</P><>如果跳过任何步骤就可能导致运行时间的崩溃,内存不够,以及其他的意想不到的状况。如果你需要使用placement new,请按照上面步骤一步步的执行.</P><
>
>第5步的执行过程是先调用析构函数再释放缓存,所以如果你想直接释放缓存,可不执行第4步而直接执行第5步!不知rashige的意见如何?</P>
| 欢迎光临 数学建模社区-数学中国 (http://www.madio.net/) | Powered by Discuz! X2.5 |