写一道小题目时发现了一个隐蔽错误,之前也没有在意过。就是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