【踩坑】unsigned int 和 signed int
【正文】
先看一段代码:
#include <iostream>
using namespace std;
int main()
{
signed int a=-2;
unsigned int b=1;
cout << a+b << endl;
system("pause");
}
输出结果是什么 呢?
并不是-2,而是4294967295,这个值恰好是2^32-1。这是因为signed int 和unsigned int 出现在一起时,unsigned int 会发生类型转换,也就是系统会将signed int 的量当成unsigned int来处理。由于,signed int在内存中按补码存储,最高位为符号位,1代表负数;unsigned int在内存中按二进制格式直接存储。因此signed int转成unsigned int 时,原来是正数的值不会改变,原来是负数会变成一个非常大的正数。例如,signed int 中的-1由于在内存中是1111 1111 1111 1111 1111 1111 1111 1111,转换成unsigned int 时值变成了4294967295=2^32-1。
【补充】
c++中string类型的成员函数length(),可以求字符串长度,其函数原型为:size_t length() const; 其中size_t是c标准库中定义的类型,是无符号的,如果直接采用string的length()作为返回值与有符号类型运算可能会发生错误。
示例代码:
#include <iostream>
#include <string>
using namespace std;
int main()
{
string a="abc";
int length=a.length();
//length是signed int 类型的3,a.length()的返回值是unsigned int 类型的3
//由于发生类型转换,没有进入循环体
for(int i=-1;i<a.length();i++)
cout << "i: " << i << endl;
//没有发生类型转换,执行4次循环体
for(int j=-1;j<length;j++)
cout << "j: " << j << endl;
system("pause");
}
运行结果: