我们先看下面的程序(假设某环境下, 用16位表示整形):
#include <iostream>
#include <string>
#include <cmath>
using namespace std;
int main()
{
int a = pow(2, 15) - 1; // 假设某环境下, 用16位表示整形
cout << a << endl; // a是最大的int值
string s(a, 'x');
cout << s << endl;
s += "test"; // ok, 此时s的长度超出了整形的最大值a
int i = 0;
for(i = 0; i < s.size(); i++) // 死循环
{
cout << s[i];
}
cout << endl << "end" << endl;
return 0;
}
需要改为:
#include <iostream>
#include <string>
#include <cmath>
using namespace std;
int main()
{
int a = pow(2, 15) - 1; // 假设某环境下, 用16位表示整形
cout << a << endl; // a是最大的int值
string s(a, 'x');
cout << s << endl;
s += "test"; // ok, 此时s的长度超出了整形的最大值a
string::size_type i = 0;
for(i = 0; i < s.size(); i++) // ok
{
cout << s[i];
}
cout << endl << "end" << endl;
return 0;
}
所以, 还是养成好习惯吧。
最后, 我们来欣赏这样一个小程序(一定要小心无符号数和负数的相互作用):
#include <iostream>
#include <string>
using namespace std;
int main()
{
if(strlen("abc") < -1)
{
cout << "yes1" << endl; // 到这个分支
}
else
{
cout << "no1" << endl;
}
if(sizeof("abc") < -1)
{
cout << "yes2" << endl; // 到这个分支
}
else
{
cout << "no2" << endl;
}
if(string("abc").size() < -1)
{
cout << "yes3" << endl; // 到这个分支
}
else
{
cout << "no3" << endl;
}
return 0;
}
ok, 先这样。