0

我知道,当我们为无符号数据类型分配负值时,它的二进制补码会被存储,即数据类型可以存储的最大值减去我们分配的负值。为了测试这一点,我编写了一个程序来说明这一点,但是我无法理解 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(...) 函数

  1. unsigned short- 2 字节,因此 -4 存储为 65532。
  2. unsigned int - 4 bytes,但是当我们在输出时尝试将其类型转换为 int 时,它在输出中显示为 -4,因此它欺骗了编译器,但是十六进制输出和逻辑比较结果表明内部表示是在两个人的恭维。
  3. char-1 字节,这是我感到困惑的地方。
  4. 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。

4

1 回答 1

3

char 不是 1 字节无符号数据类型吗?

也许,也许不是。的签名char是实现定义的。

在您当前的实现中,它显然是签名的。

在该compare方法的输出中,您会看到显示的四个字节,因为您将其转换int为输出,因此charvalue-4被转换为intvalue -4

于 2012-10-14T20:46:10.227 回答