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