真正的拷貝構(gòu)造函數(shù)或者拷貝賦值運(yùn)算符只對完全相同類型的對象施以構(gòu)造或賦值操作,并且,其如果是一個模板類的話,模板的參數(shù)也必須完全相同。模板“構(gòu)造函數(shù)”和模板“賦值運(yùn)算符”都不是真正的拷貝構(gòu)造函數(shù)和賦值運(yùn)算符,因此這種模板函數(shù)的出現(xiàn)并不會隱藏原來隱含的拷貝構(gòu)造函數(shù)的聲明。
文章來源:
http://my.donews.com/robinchow/2007/01/10/lhiltldtjwkukgbtacjqkosnhqibccxojgzc/
標(biāo)準(zhǔn)庫中 string 的模板類:
template<class charT,
class traits= char_traits
class Allocator = allocator<charT> >
class basic_string;
其中 char_traits 部分,它決定了字符的相互作用和比較運(yùn)算,如eq()(相等)、ne()(不等)、lt()(小于)、compare()(比較字符序列)、find()(搜索字符序列)。因此只需重定義 char_traits 模板即可改變 string 的字符比較操作。
文章來源:
http://my.donews.com/robinchow/2007/01/10/cfjorztxnorsmkaafyrckgebtdmemrppxzeo/
設(shè)計(jì)準(zhǔn)則:絕對不要解引用一個無效的 iterator。
摘要:
- 有效的數(shù)值:iterator 指向的位置有效。
- 有效的壽命:iterator 使用時仍然有效。
- 有效的范圍:一對 iterators 組成一個有效的范圍,first 在 last 之前(或相等),并且兩者指向同一個container。
- 防止不合法的操作行為,如修改內(nèi)置類型的暫時對象。
文章來源:
http://my.donews.com/robinchow/2007/01/10/rwyjwpstnlvfjtxeqzrupbzdkijaqyohunrq/
C++ 中 bool 是一個基本類型,可以通過各種方法來模擬它,但是都存在不同的缺陷:
- 使用 typedef 模擬,bool 不允許重載。
- 使用 #define,bool 不允許重載且通常破壞了 #define。
- enum bool允許重載但在條件表達(dá)式中不能進(jìn)行自動類型轉(zhuǎn)換。bool b = (i == j)是錯誤的,因?yàn)?int 不能隱含地轉(zhuǎn)換成 enums。
- bool 類允許重載但不能讓 bool 對象在條件中作測試,除非它能提供自動轉(zhuǎn)換到基本類型,但是提供自動轉(zhuǎn)換卻通常會干擾函數(shù)重載解析過程。
文章來源:
http://my.donews.com/robinchow/2007/01/15/bszvusphgepqbphvticopjkpfadfapccibyd/
使用 auto_ptr(靈巧指針)的注意事項(xiàng):
- 對于 auto_ptr,拷貝不是對等的。右側(cè)的對象不再擁有對象的所有權(quán)。
- 不再擁有所有權(quán)的 auto_ptr 的指針會被置為 NULL,因而對它的解引用會導(dǎo)致錯誤。
- 使用 const auto_ptr 可以防止將該靈巧指針賦值給其他靈巧指針。
文章來源:
http://my.donews.com/robinchow/2007/01/14/xzuxgvbkpleammqcmlzlsjhkcqmgfdpddjaj/