数学建模社区-数学中国

标题: 如何定位放置new [打印本页]

作者: rashige    时间: 2004-4-29 10:07
标题: 如何定位放置new
<>来自:ZDNet</P>
7 l2 C+ A9 d" I5 m5 S, s2 C0 P) N<>标准首部<NEW>由一个特别的操作符new来定义,这个就是我们熟知的placement new。和其他普通的new不同的是,它在括号里多了另外一个参数。比如:   h7 F6 v8 c- X6 M
<TABLE cellSpacing=0 cellPadding=0 width=0 align=right border=0>& M+ M; @5 Q( d' ^" Z7 @
0 n( L/ R  C" x, m* N, Y( H
<TR>
8 w% @; J' j5 B. T4 N' |<TD></TD></TR></TABLE></P>
. V( U/ q3 ]- C<><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>
( f. w$ d$ b8 x4 \1 N- N<H5>使用方法</H5>+ @" |2 C7 L6 m( D( D
<>在一些时候placement new的使用方法和其他普通的new不同。这里提供了它的使用方法。</P>: {- s. J  l3 d7 x) s* I
<H5>第一步  缓存提前分配</H5>' i! z- ~% ]& S; L/ e- Y
<>确定被placement new使用的缓存区的内存队列已经准备好,使用普通的new来分配它:</P>
, q8 C6 g* B/ z$ k4 W% l" K6 L# K<><FONT color=#0066ff>class Task {/*..*/};+ I8 m+ q- F* g6 b' P) r3 l! I
char * buff = new [sizeof(Task)];</FONT> <FONT color=#006600>//分配内存</FONT></P>
, M1 J' K5 o9 [$ Z' ^<H5><FONT color=#000000>第二步:对象的分配</FONT></H5>
: X  T+ q& P9 n<>在刚才已分配的缓存区调用placement new来构造一个对象。</P>+ p1 n  u8 k: @4 g) |
<><FONT color=#0066ff>Task *ptask = new(buff) Task</FONT></P># m1 |% Z# M" [2 [" W
<H5><FONT color=#000000>第三步:使用</FONT></H5>  q& V  w; G4 F5 }  W/ n0 c
<>按照普通方式利用分配的对象:</P>/ a8 F. u8 D5 ~  A
<><FONT color=#0066ff>ptask-&gt;suspend();; p9 ~, H; w2 T/ ?' m8 W% E
ptask-&gt;resume();</FONT>
* a9 W: P% p1 {3 Y% a<FONT color=#006600>//... </FONT></P>
) O5 e- z. X5 E8 R8 Z- r6 y<H5>第四步:对象的毁灭</H5>
* d$ \5 [& U$ ^<>一旦你使用完这个对象,你必须调用它的析构函数来毁灭它。按照下面的方式调用析构函数:</P>
: i- K4 f8 h/ a! V<><FONT color=#0066ff>ptask-&gt;~Task();</FONT> <FONT color=#006600>//调用外在的析构函数</FONT></P>% b" w# P, k& @
<H5>第五步:释放</H5>
+ C4 P: G% b6 m4 ]3 ?/ O<>你可以反复利用缓存并给它分配一个新的对象(重复步骤2,3,4)如果你不打算再度使用这个缓存,你可以象这样释放它:</P>
5 V5 v; @- u  \- E# e. C/ _<><FONT color=#0066ff>delete [] buff;</FONT></P>- i# N4 p! A1 k- B2 f
<>如果跳过任何步骤就可能导致运行时间的崩溃,内存不够,以及其他的意想不到的状况。如果你需要使用placement new,请按照上面步骤一步步的执行</P>
作者: ilikenba    时间: 2004-4-29 14:52
<>如果跳过任何步骤就可能导致运行时间的崩溃,内存不够,以及其他的意想不到的状况。如果你需要使用placement new,请按照上面步骤一步步的执行.</P><>
</P><>第5步的执行过程是先调用析构函数再释放缓存,所以如果你想直接释放缓存,可不执行第4步而直接执行第5步!不知rashige的意见如何?</P>




欢迎光临 数学建模社区-数学中国 (http://www.madio.net/) Powered by Discuz! X2.5