???動態分配的對象:程序員完全控制分配與釋放,分配在程序的空閑存儲區(free store)的可用內存池中。
?
?1)單個對象的動態分配與釋放;
?new表達式沒有返回實際分配的對象,而是返回指向該對象的指針。對該對象的全部操作都要通過這個指針間接完成。
?隨機分配的內存具有隨機的位模式,建議初始化,例如:
?int* pi = new int(0);
?
?這樣做沒有必要:
????
if
?(?pi?!=?0?)
????????delete?pi;
?
說明:如果指針操作數被設置為0,則C++保證delete表達式不會調用操作符delete()。所以沒有必要測試其是否為0。
?在delete表達式之后,pi被稱作空懸指針,即指向無效內存的指針。空懸指針是程序錯誤的根源,建議對象釋放后,將該指針設置為0。
?
?2)auto_ptr
?auto_ptr是C++標準庫提供的類模板,它可以幫助程序員自動管理用new表達式動態分配的單個對象,但是,它沒有對數組管理提供類似支持。它的頭文件為:

?
當auto_ptr對象的生命期結束時,動態分配的對象被自動釋放。
?auto_ptr類模板背后的主要動機是支持與普通指針類型相同的語法,但是為auto_ptr對象所指對象的釋放提供自動管理。例:
?auto_ptr
類模板支持所有權概念,當一個auto_ptr對象被用另一個auto_ptr對象初始化賦值時,左邊被賦值或初始化的對象就擁有了空閑存儲區內底層對象的所有權,而右邊的auto_ptr對象則撤消所有責任。例:
?
判斷是否指向一個對象,例:
????auto_ptr < int > ?p_auto_int;????
???? if ?(?p_auto_int. get ()? == ? 0 ?)
????????

???? else
???????? // ?重置底層指針,必須使用此函數????????
????????p_auto_int.reset(? new ? int (? 1024 ?)?);
?3)數組的動態分配與釋放
?建議使用C++標準庫string,避免使用C風格字符串數組。
?為避免動態分配數組的內存管理帶來的問題,一般建議使用標準庫vector、list或string容器類型。
?
?4)常量對象的動態分配與釋放
?可以使用new表達式在空閑存儲區內創建一個const對象,例:
?
我們不能在空閑存儲區創建內置類型元素的const數組,原因是:我們不能初始化用new表達式創建的內置類型數組的元素。例:
?5
)定位new表達式
?new表達式的第三種形式允許程序員要求將對象創建在已經被分配好的內存中。稱為:定位new表達式(placement new expression)。程序員在new表達式中指定待創建對象所在的內存地址。如下所示:
?new (place_address) type-specifier
?注意:place_address必須是個指針,必須包含頭文件<new>。這項設施允許程序員預分配大量的內存,供以后通過這種形式的new表達式創建對象。例如:




























