寫一道小題目時發現了一個隱蔽錯誤,之前也沒有在意過。就是string.size()返回的是size_type類型,而size_type等同於unsigned int
那道小題目如下:
當時寫的代碼如下:
1 #include <iostream>
2 #include <string>
3 using namespace std; 4
5 int main() 6 { 7 int N; 8 string name; 9 int maxsize = -1; 10 string maxsizename; 11 cin >> N; 12 for (int i = 0; i < N; i++) 13 { 14 cin >> name; 15 if (name.size() > maxsize) 16 { 17 maxsize = name.size(); 18 maxsizename = name; 19 } 20 } 21 cout << maxsizename; 22 return 0; 23 }
這里什么結果都輸不出來,然后調試時發現到第15行的判斷語句時name.size()比maxsize長依舊沒有進入后面的語句。然后突然記起來。。看CMU的CSAPP時說到了unsigned int和int之間作比較的一些看起來很奇怪的結果。
這里maxsize被初始化為-1,作為帶符號整數,它的二進制碼應該為全1
當int類型和unsigned int類型做比較,會被強制轉型為unsigned int類型,而上面代碼中maxsize和name.size()比較正是unsigned類型的比較。
此時由於maxsize二進制為全1,是unsigned int類型中最大的數,所以無論如何都進不了后面的語句。
和size_type有關的還有size_t,他們之間的關系如下:
為了使自己的程序有很好的移植性,c++程序員應該盡量使用size_t和size_type而不是int, unsigned
1. size_t是全局定義的類型;size_type是STL類中定義的類型屬性,用以保存任意string和vector類對象的長度
2. string::size_type 制類型一般就是unsigned int, 但是不同機器環境長度可能不同 win32 和win64上長度差別;size_type一般也是unsigned int
3. 使用的時候可以參考:
string::size_type a =123;
vector<int>size_type b=234;
size_t b=456;
4. size_t 使用的時候頭文件需要 <cstddef> ;size_type 使用的時候需要<string>或者<vector>
5. sizeof(string::size_type)
sizeof(vector<bool>::size_type)
sizeof(vector<char>::size_type)
sizeof(size_t)
上述長度均相等,長度為win32:4 win64:8
6. 二者聯系:在用下標訪問元素時,vector使用vector::size_type作為下標類型,而數組下標的正確類型則是size_t
(轉載自http://www.cnblogs.com/kaituorensheng/p/3239446.html)
在寫代碼的過程中,遇到的返回size_t或size_type的還有sizeof,strlen