我知道,当我们为无符号数据类型分配负值时,它的二进制补码会被存储,即数据类型可以存储的最大值减去我们分配的负值。为了测试这一点,我编写了一个程序来说明这一点,但是我无法理解 char 数据类型的行为。
#include <iostream>
using namespace std;
template<class T>
void compare(T a,T b)
{
cout<<dec<<"a:"<<(int)a<<"\tb:"<<(int)b<<endl; //first line
cout<<hex<<"a:"<<(int)a<<"\tb:"<<(int)b<<endl; //second line
if(a>b)
cout<<"a is greater than b"<<endl;
else
cout<<"b is greater than a"<<endl;
}
int main()
{
unsigned short as=2;
unsigned short bs=-4;
compare(as,bs);
unsigned int al = 2;
unsigned int bl =-4;
compare(al,bl);
char ac=2;
char bc=-4;
compare(ac,bc);
int ai =2;
int bi =-4;
compare(ai,bi);
}
输出是
a:2 b:65532
a:2 b:fffc
b is greater than a
a:2 b:-4
a:2 b:fffffffc
b is greater than a
a:2 b:-4
a:2 b:fffffffc
a is greater than b
a:2 b:-4
a:2 b:fffffffc
a is greater than b
使用不同数据类型的参数多次调用 compare(...) 函数
- unsigned short- 2 字节,因此 -4 存储为 65532。
- unsigned int - 4 bytes,但是当我们在输出时尝试将其类型转换为 int 时,它在输出中显示为 -4,因此它欺骗了编译器,但是十六进制输出和逻辑比较结果表明内部表示是在两个人的恭维。
- char-1 字节,这是我感到困惑的地方。
- int - 4 bytes,有符号数据类型,没有意外,正常结果。
我要问的问题是为什么 char 表现得像一个有符号的 int?即使我们在输出结果的第一行之前将类型转换为 int,为什么 char 显示的值类似于 int,即使 char 是 1 字节而 int 是 4 字节。unsigned short 显示不同的值,因为它的内存要求是 2 字节。unsigned int 和 int 在结果的第一行显示相同的结果,因为两者都是 4 个字节,编译器被成功欺骗,并且是可以接受的。但是为什么char也显示相同的值,好像它的内存布局和int一样呢?
并且逻辑比较还表明 char 不是无符号数据类型,而是有符号数据类型。无符号数据类型显示 b 大于一。虽然 char 显示 a 大于 b ,但就带符号数据类型而言。为什么?
char 不是 1 字节无符号数据类型吗?这是我在 B.Tech 学位上学习 C 和 C++ 课程时学到的。
任何解释都会有所帮助。使用的编译器是 mingw 2.19.1。