变量的属性——unsigned和signed

问题:C语言是如何表示一个数为负数和整数的?

因此在C语言中,增加了两个关键字用于表示整数和负数。
1. signed表示未有符号的类型
2. unsigned则表示无符号类型
3. C语言中只有整数类型能够声明unsigned变量
4. C语言中变量默认为有符号类型

计算机中的符号位

数据类型的最高位用于标识数据的符号
1. 最高位为1,表明这个数为负数
2. 最高位为0,表明这个数为正数

示例代码:有符号数的符号位

int main ()
{
    char c = - 5;
    short s = 6 ;

    printf ( "%d\n" , ( (c & 0x80 ) != 0 ));
    printf ( "%d\n" , ( (s & 0x8000 ) != 0 ));

    return 0 ;
}

输出结果:
1
0

有符号数的表示法

实际上,在计算机内部用补码表示有符号数
1. 正数的补码为正数本身
2. 负数的补码为负数的绝对值各位取反后加1

例:
1.8位整数5的补码:0000 0101
2.8位整数-7的补码:1111 1001

无符号数的表示法

在计算机内部用原码表示无符号数
1. 无符号数默认为正数
2. 无符号数没有符号位

对于固定长度的无符号数
1.MAX_VALUE + 1 -> MIN_VALUE
2.MIN_VALUE - 1 -> MAX_VALUE

示例代码:错误使用了unsigned

int main ()
{
    unsigned int i = 0 ;

    for (i = 9; i >=0 ; i --)
    {
        printf ( "i = %u\n" , i );
    }

    return 0 ;
}

输出结果:不停的打印结果。
实际上,unsigned声明的变量不可能小于等于0。

当无符号数遇上有符号数

如果无符号数与有符号数混合运算,会产生什么样的结果呢?

示例代码:

int main ()
{
    unsigned int i = 5 ;
    int j = - 10;

    if ( (i + j ) > 0 )
    {
        printf ( "i + j > 0\n" );
    }
    else
    {
        printf ( "i + j <= 0\n" );
    }

    printf ( "i + j = %d\n" ,(i + j ));

    return 0 ;
}

输出结果:
i + j > 0
i + j = -5

问题:安装我们的运算结果,应为为5+(-10) = -5,i+j应该是小于0的。那么为什么输出结果却是i+j>0呢?
1.当有符号数j和无符号数i进行比较运算时,会将有符号数转换为无符号数后再进行计算,结果为无符号数,所以输出i+j>0。
2.那么为什么输出结果却是i+j = -5呢?这是因为%d默认是按有符号int类型输出的。这也说明了有符号无符号并不是影响输出结果。

猜你喜欢

转载自blog.csdn.net/small_prince_/article/details/80562715