這是在看完了C++ Primer這本書之後又回過頭來碼的筆記,在看的時候也發現,看到後面,前面就忘了,有點像狗熊掰玉米。。。所以決定回過頭來再過一遍,這一次只看那些比較重要的知識點,太詳細了也終歸還是記不住。另外,這篇博客是使用 Markdown寫的,第一次用,估計寫出來的格式可能會有點醜。。 1. ...
這是在看完了C++ Primer這本書之後又回過頭來碼的筆記,在看的時候也發現,看到後面,前面就忘了,有點像狗熊掰玉米。。。所以決定回過頭來再過一遍,這一次只看那些比較重要的知識點,太詳細了也終歸還是記不住。另外,這篇博客是使用 Markdown寫的,第一次用,估計寫出來的格式可能會有點醜。。
1.位於頭文件中的代碼一般不應該使用 using聲明。這是因為該文件還會被其他文件包含,在頭文件中使用 using聲明的話,其他文件中就也有了這個聲明,可能造成名字衝突。
2.使用形如 cin >> s的形式讀入 string對象,會自動忽略開頭的空白(空格、換行、製表符等)並從第一個真正的字元開始讀起,直到遇見下一處空白為止。不過標點符號還是會被讀取進來的。
3.getline一遇到換行符就結束讀取操作並返回結果,哪怕輸入的一開始就是換行符也是如此,不過讀入的換行符也還是會被丟棄。
4.與 string下標和長度有關的變數應該使用 size::type類型,千萬不要將 size::type和 int型混用!
5.string下標訪問運算符 []返回值是該位置上字元的引用。
6.vector中存儲的元素類型必須可以被賦值,所以元素類型不能是引用和常量。另外,因為新標準中有一個 vector(n, val)的構造函數,所以元素類型必須要有預設構造函數。
7.初始化時使用了花括弧的形式但是提供的值又不能用來列表初始化,編譯器會嘗試使用提供的值來構造 vector對象。
vector<string> v5{"hi"}; // 列表初始化:v5有一個元素
vector<string> v6("hi"); // 錯誤:不能使用字元串字面值構建 vector對象
vector<string> v7{10, "hi"}; // v7有10個值為“int”的元素
8.vector本身是一個模板,對象類型總是包含著元素類型
vector<int>::size_type // 正確
vector::size_type // 錯誤
9.for迴圈中應儘量使用 !=或 ==,而非 <、>、<=、>=等關係運算符,因為並不是所有類型都定義了關係運算符。使用相等性操作,這種編程風格在標準庫提供的所有容器上都有效,適用性更廣泛。
10.it是一個迭代器類型,則對於以下形式,圓括弧必不可少。因為點運算符優先順序更高。
(*it).empty();
11.容器的下標類型 size_type,迭代器的距離類型 difference-type;
內置數組,下標類型為 size_t,指針距離類型為 ptrdiff_t。
12.對於內置數組,元素類型和個數都是類型的一部分,因此,定義數組時,其維度要是已知的,必須為一個常量表達式。
1. 與內置類型一樣,在函數內部定義的內置類型的數組,預設初始化會令數組含有未定義的值。
2. 字元數組可以用字元串字面值進行初始化,要註意,字元串字面值的結尾處有一個空字元,這個空字元也會被拷貝到字元數組中。所以在定義字元數組的大小時,要考慮到這個空字元。
char a1[] = {'C', '+', '+'}; // 列表初始化,沒有空字元
char a2[] = {'C', '+', '+', '\0'}; // 列表初始化,含有顯式的空字元
char a3[] = "C++"; // 自動添加表示字元串結束的空字元
const char a4[3] = {'C', '+', '+'}; // 錯誤:沒有空間存放空字元
3. 不允許數組間的拷貝初始化和賦值操作
4. 在很多使用數組名字的地方,編譯器會將它轉換成指針。當使用數組類型作為 auto變數的初始值時,推斷得到的是指針而非數組;而使用 decltype得到的是數組類型。
int ia[] = {0, 1, 2, 3, 4};
auto ia2(ia); // ia2 是一個整型指針,指向 ia的第一個元素
decltype(ia) ia3; // ia3 是一個整型數組
5. C++11新標準引入了 begin和 end兩個函數,使得內置數組也可以像 STL中的容器那樣操作迭代器。註意這兩個函數不是成員函數,使用時要用數組作為它們的參數。
6. 內置數組的下標類型不是無符號類型,可以是負值,但結果地址必須指向原指針所指向的同一數組中的元素。
int ia[] = {0, 1, 2, 3, 4};
int *p = ia[2]; // 指向 ia[2]
int k = p[-2]; // 指向 ia[0]
13.對於適用於 C風格字元串的函數 strlen、strcmp等,傳入此函數的指針必須指向以空字元結束的數組,沒有空字元,就無法判斷字元數組在記憶體中的結束位置。
14.現代的 C++程式應儘量使用 vector和迭代器,避免使用內置數組和指針;應該儘量使用 string,避免使用 C風格的基於數組的字元串。因為使用 C風格的編程風格容易引發語法和繁瑣細節上的錯誤。
15.在使用範圍 for語句處理多維數組時,除了最內層的迴圈外,其他所有迴圈的控制變數都應該是引用類型。比如對於以下形式
for (auto row : ia)
for (auto col : row)
在遍歷內迴圈時,因為 row不是引用類型,所以編譯器初始化 row時會自動將這些數組形式的元素轉換成指向首元素的指針,這樣 row的類型就是 int*,顯然內層迴圈就不合法了。