C语言中有符号数和无符号数进行运算(包括逻辑运算和算术运算)默认会将有符号数看成无符号数进行运算,其中算术运算默认返回无符号数,逻辑运算当然是返回0或1了。
unsigned int和int进行运算
直接看例子来说明问题吧
#include
using namespace std;
int main()
{
int a = -1;
unsigned int b = 16;
if(a > b)
cout<
return 0;
}
输出结果为:
这是因为a和b进行比较的时候,编译器将有符号数a看成了无符号数,然后再和b进行比较,在内存中(32位)
a : 11111111 11111111 11111111 11111111
b : 00000000 00000000 00000000 00010000
看成无符号数,自然是a>b。
#include
using namespace std;
int main()
{
int a = -1;
unsigned int b = 16;
cout<
int c = -16;
unsigned int d = 15;
cout<
return 0;
}
输出结果为:
可以看到a+b的结果貌似比较正常,但是c+d和我们想象的好像不太一样。其实4294967295就是11111111 1111111 11111111 1111111就是-1在内存中的形式,看成无符号数就是这个结果啦。所以unsigned int和int做运算会将int看成unsigned int,而且结果也是unsigned int。
unsigned char和char进行运算
看一个颠覆上面逻辑的例子:
#include
using namespace std;
int main()
{
char a = -16;
unsigned char b = 14;
if(a > b)
cout<
cout<