有符号与无符号

原创 2015年11月17日 19:48:31

有符号与无符号

数据类型的最高位用于标识数据的符号

最高位为1,表示这个数为负数

最高位为0,表示这个数为正数


#include <stdio.h>
int main()
{
char a = -5;
short s = 6;
int i = -7;
printf("%d\n",((a & 0x80) !=0));
printf("%d\n",((s & 0x8000) !=0));
printf("%d\n",((i & 0x80000000) !=0));
    return 0;
}

运行结果:



在计算机中用补码表示有符号数

正数的补码为正数本身
负数的补码为负数的绝对值各位取反后加1

8位整数5的补码为:      0000 0101
8位整数-7的补码为:     1111 1001
16位整数20的补码为: 0000 0000 0001 0100
16位整数-13的补码为:1111 1111 1111 0011

-7 ==>0000 0111 ==>1111 1000 ==>1111 1001 

无符号数的表示法

计算机内部用源码表示无符号数
无符号数默认为正数
无符号数没有符号位

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


C语言中变量默认为有符号类型


unsigned关键字声明变量为无符号类型(C语言中只有整数类型能够声明unsigned变量

#include <stdio.h>
int main()
{
    unsigned int i = 5;
    int j = -10;
    if( (i + j) > 0 )
    {
        printf("i + j > 0\n");
    }
    else
    {
        printf("i + j <= 0\n");
    }
    return 0;
}
运行结果:



分析:无符号数与有符号数进行运算时,有符号数将被看做无符号数,由于负数在内存中表示最高位为1,被看做无符号之后将变成很大的正数。所以结果大于0。


#include <stdio.h>
int main()
{
    unsigned int i = 0;
    
    for(i=9; i>=0; i--)
    {
        printf("i = %u\n", i);
    }
    return 0;
}
运行结果:(无限循环)


分析:i从9减到0之后再减1,就变成4字节的最大值
版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

字符串与整数、浮点数、无符号整数之间的转换常用函数

atof(将字符串转换成浮点型数) 表头文件 #include 定义函数 double atof(const char *nptr); 函数说明 atof()会扫描参数nptr字符串,跳过前...

无符号整形的reserve bits的优化方案

[c] view plaincopy 0010 0000 => 0000 0100   具体的转换是从MSB->LSB到LSB->MSB, 所有的Bit都必须反...

无符号整数

使用移位操作符实现无符号整数位反转

>> 左移 各二进位全部左移若干位,高位丢弃,低位补0 >>  右移 各二进位全部右移若干位,对无符号数,高位补0,有符号数,各编译器处理方法不一样,有的补符号位(算术右移),有的补0(逻辑右移)。 ...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)