31、動態(tài)空間的釋放(P119)
動態(tài)空間的釋放使用delete [] pia;(其中pia為指向動態(tài)分配的數(shù)組的第一個元素的指針)。在關鍵字delete和指針之間的方括號對是必不可少的:它告訴編譯器該指針指向的是自由存儲區(qū)中的數(shù)組,而并非單個對象。
如果遺漏了空方括號對,這是一個編譯器無法發(fā)現(xiàn)的錯誤,將導致程序在運行時出錯。
使用std::string后則會自動進行釋放,無需delete!
32、c_str返回的數(shù)組并不保證一定是有效的……
std::string st1("I am a string object!");
//error C2440: “初始化”: 無法從“const char *”轉換為“char *”
//char *str = st1.c_str();
const char *cstr = st1.c_str();
std::cout<<cstr<<std::endl;
c_str返回的數(shù)組并不保證一定是有效的,接下來對st1的操作有可能會改變st1的值,使剛才返回的數(shù)組失效。如程序需要持續(xù)訪問該數(shù)據(jù),則應該復制c_str函數(shù)返回的數(shù)組。
33、指向函數(shù)的指針
詳見《指向函數(shù)的指針的一點理解》
34、容器初始化
在大多數(shù)的程序中,使用默認構造函數(shù)能達到最佳運行時性能,并且使容器更容易使用。
35、容器頭文件
#include <vector>
#include <list>
#include <deque> //雙端隊列“double-ended queue”,發(fā)音為“deck”
標準庫定義了以上三種順序容器類型。
36、容器的容器
必須用空格隔開兩個相鄰的>符號,以示這是兩個分開的符號,否則,系統(tǒng)會認為>>是單個符號,為右移操作符,并導致編譯時錯誤。
int m, n;
m = 5;
n = 3;
cout << "Print a line!" << endl;
vector<string> lines(n, " I_am_a_PC_! ");
for (vector<string>::iterator siter = lines.begin(); siter != lines.end(); ++siter) {
cout << *siter;
}
cout << endl;
cout << "Print a paragraph!" << endl;
vector<vector<string> > paragraph(m, lines);
for (vector<vector<string> >::iterator piter = paragraph.begin(); piter
!= paragraph.end(); ++piter) {
for (vector<string>::iterator siter = (*piter).begin(); siter
!= (*piter).end(); ++siter) {
cout << *siter << ends;
}
cout << endl;
}
37、迭代器范圍(P269)
C++定義的容器類型中,只有vector和deque容器提供下面兩種重要的運算集合:迭代器算術運算,以及使用除了==和!=之外的關系操作符來比較兩個迭代器(==和!=這兩種關系運算適用于所有容器)。
list容器的迭代器既不支持算術運算(減法或加法),也不支持關系運算(<=,<,>=,>)它只提供前置和后置的自增、自減以及相同(不等)運算。
38、容器元素都是副本
在容器中添加元素時,系統(tǒng)是將元素值復制到容器里的。類似地,使用一段元素初始化新容器時,新容器存放的是原始元素的副本。被復制的原始值與新容器中的元素各不相關,此后容器內(nèi)元素值發(fā)生變化時,被復制的原值不會受到影響,反之亦然。
39、下標操作和.at(n)的區(qū)別
vector<string> svec; //empty vector;
cout << svec[0]; //run-time error:There are no elements in svec!
cout << svec.at(0); //throws out_of_range exception
40、容器的賦值(P283)
assign操作首先刪除容器中所有的元素,然后將其參數(shù)所指定的新元素插入到該容器中。與復制容器元素的構造函數(shù)一樣,如果兩個容器類型相同,其元素類型也相同,就可以使用賦值操作符(=)將一個容器賦值給另一個容器。如果在不同(或相同)類型的容器內(nèi),元素類型不相同但是相互兼容,則其賦值運算必須使用assign函數(shù)。例如,可通過assign操作實現(xiàn)將vector容器中一段char*類型的元素賦給string類型的list容器。
由于assign操作首先刪除容器中原來存儲的所有元素,因此,傳遞給assign函數(shù)的迭代器不能指向調用該函數(shù)的容器內(nèi)的元素。