string.size()和size_type

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

原文地址:https://www.cnblogs.com/jiongyy0570/p/10349713.html