原码、反码、补码转换。short、int、long类型有无符号位输出

本文探讨了在Windows环境下,使用Visual C++ 6.0编译器,关于short、int、long类型的有符号和无符号数值在原码、反码、补码转换中的表现。详细分析了不同数值在二进制和十六进制下的变化,并解释了数据溢出的情况。

short、int、long类型有符号位输出和无符号位输出的数值问题
原码、反码、补码转换
系统:windows 32/windows 64
软件:Visual C++ 6.0

#include<stdio.h>
void main()
{
    printf("                  类型 = 字节数\n");
    printf("         sizeof(short) = %d\n",sizeof(short));  
    printf("sizeof(unsigned short) = %d\n",sizeof(unsigned short));
    printf("           sizeof(int) = %d\n",sizeof(int));    
    printf("  sizeof(unsigned int) = %d\n",sizeof(unsigned int));
    printf("          sizeof(long) = %d\n",sizeof(long));   
    printf(" sizeof(unsigned long) = %d\n",sizeof(unsigned long));  
}

运行结果:
这里写图片描述
long类型为四个字节,取值范围为-2^31~2^31-1,即-2147483648~2147483647

#include<stdio.h>
void main()
{
    long i = 2147483648;
    long _i = -2147483648;
    long maxi = 2147483649;
    long _maxi = -2147483649;
    long mini = 2147483647;
    long _mini = -2147483647;
    printf("       数值 = 无符号八进制       有符号十进制    无符号十进制    无符号十六进制\n");
    printf(" 2147483647 = %o\t %d\t %u\t %x\n",mini,mini,mini,mini);
    printf("-2147483647 = %o\t %d\t %u\t %x\n",_mini,_mini,_mini,_mini);
    printf(" 2147483648 = %o\t %d\t %u\t %x\n",i,i,i,i);
    printf("-2147483648 = %o\t %d\t %u\t %x\n",_i,_i,_i,_i);
    printf(" 2147483649 = %o\t %d\t %u\t %x\n",maxi,maxi,maxi,maxi);
    printf("-2147483649 = %o\t %d\t %u\t %x\n",_maxi,_maxi,_maxi,_maxi);    
}

运行结果:
这里写图片描述
解析:正数的原码与补码相同、负数的补码为模数减去负数的绝对值(即负数的原码取反加一【注意数据溢出】)
2147483647的二进制
原码:0111 1111 1111 1111 1111 1111 1111 1111
补码:0111 1111 1111 1111 1111 1111 1111 1111
十六进制:0x7FFF FFFF

-2147483647的二进制
原码:0111 1111 1111 1111 1111 1111 1111 1111
反码:1000 0000 0000 0000 0000 0000 0000 0000
补码:1000 0000 0000 0000 0000 0000 0000 0001
十六进制:0x8000 0001

2147483648的二进制
原码:1000 0000 0000 0000 0000 0000 0000 0000
补码:1000 0000 0000 0000 0000 0000 0000 0000
十六进制:0x8000 0000

-2147483648的二进制
原码:1000 0000 0000 0000 0000 0000 0000 0000
反码:0111 1111 1111 1111 1111 1111 1111 1111
补码:1000 0000 0000 0000 0000 0000 0000 0000
十六进制:0x8000 0000

2147483649的二进制
原码:1000 0000 0000 0000 0000 0000 0000 0001
补码:1000 0000 0000 0000 0000 0000 0000 0001
十六进制:0x8000 0001

-2147483649的二进制
原码:1000 0000 0000 0000 0000 0000 0000 0001
反码:0111 1111 1111 1111 1111 1111 1111 1110
补码:0111 1111 1111 1111 1111 1111 1111 1111
十六进制:0x7FFF FFFF

2147483647的值等于-2147483649
2147483649的值等于-2147483647
2147483648的值等于-2147483648
因为2147483648是最大值,也是最小值。2147483649相当于从-2147483648加一进入到了负数那边(即-2147483648+1)。同理,-2147483649相当于从2147483648减一进入到正数那边(即2147483648-1)
这里写图片描述
unsigned long类型为四字节,取值范围为0~2^32-1,即0~4294967295

#include<stdio.h>
void main()
{
    unsigned long i = 4294967295;
    unsigned long _i = -4294967295;
    unsigned long maxi = 4294967296;
    unsigned long _maxi = -4294967296;
    unsigned long mini = 4294967294;
    unsigned long _mini = -4294967294;
    printf("       数值 = 无符号八进制 有符号十进制 无符号十进制 无符号十六进制\n");
    printf(" 4294967294 = %o\t %d\t %u\t %x\n",mini,mini,mini,mini);
    printf("-4294967294 = %o\t\t\t %d\t %u\t\t %x\n",_mini,_mini,_mini,_mini);
    printf(" 4294967295 = %o\t %d\t %u\t %x\n",i,i,i,i);
    printf("-4294967295 = %o\t\t\t %d\t %u\t\t %x\n",_i,_i,_i,_i);
    printf(" 4294967296 = %o\t\t\t %d\t %u\t\t %x\n",maxi,maxi,maxi,maxi);
    printf("-4294967296 = %o\t\t\t %d\t %u\t\t %x\n",_maxi,_maxi,_maxi,_maxi);  
}

运行结果:
这里写图片描述
int类型为四个字节,取值范围为-2^31~2^31-1,即-2147483648~2147483647

#include<stdio.h>
void main()
{
    int i = 2147483648;
    int _i = -2147483648;
    int maxi = 2147483649;
    int _maxi = -2147483649;
    int mini = 2147483647;
    int _mini = -2147483647;
    printf("       数值 = 无符号八进制       有符号十进制    无符号十进制    无符号十六进制\n");
    printf(" 2147483647 = %o\t %d\t %u\t %x\n",mini,mini,mini,mini);
    printf("-2147483647 = %o\t %d\t %u\t %x\n",_mini,_mini,_mini,_mini);
    printf(" 2147483648 = %o\t %d\t %u\t %x\n",i,i,i,i);
    printf("-2147483648 = %o\t %d\t %u\t %x\n",_i,_i,_i,_i);
    printf(" 2147483649 = %o\t %d\t %u\t %x\n",maxi,maxi,maxi,maxi);
    printf("-2147483649 = %o\t %d\t %u\t %x\n",_maxi,_maxi,_maxi,_maxi);
}

运行结果:
这里写图片描述
unsigned int类型为四字节,取值范围为0~2^32-1,即0~4294967295

#include<stdio.h>
void main()
{
    unsigned int i = 4294967295;
    unsigned int _i = -4294967295;
    unsigned int maxi = 4294967296;
    unsigned int _maxi = -4294967296;
    unsigned int mini = 4294967294;
    unsigned int _mini = -4294967294;
    printf("       数值 = 无符号八进制       有符号十进制    无符号十进制    无符号十六进制\n");
    printf(" 4294967294 = %o\t %d\t %u\t %x\n",mini,mini,mini,mini);
    printf("-4294967294 = %o\t\t\t %d\t %u\t\t %x\n",_mini,_mini,_mini,_mini);
    printf(" 4294967295 = %o\t %d\t %u\t %x\n",i,i,i,i);
    printf("-4294967295 = %o\t\t\t %d\t %u\t\t %x\n",_i,_i,_i,_i);
    printf(" 4294967296 = %o\t\t\t %d\t %u\t\t %x\n",maxi,maxi,maxi,maxi);
    printf("-4294967296 = %o\t\t\t %d\t %u\t\t %x\n",_maxi,_maxi,_maxi,_maxi);
}

运行结果:
这里写图片描述
short类型为两个字节,取值范围为-2^15~2^15-1,即-32768~32767

#include<stdio.h>
void main()
{
    short i = 32768;
    short _i = -32768;
    short maxi = 32769;
    short _maxi = -32769;
    short mini = 32767;
    short _mini = -32767;
    printf("  数值 = 无符号八进制 有符号十进制 无符号十进制 无符号十六进制\n");
    printf(" 32767 = %o\t\t %d\t %u\t\t %x\n",mini,mini,mini,mini);
    printf("-32767 = %o\t %d\t %u\t %x\n",_mini,_mini,_mini,_mini);
    printf(" 32768 = %o\t %d\t %u\t %x\n",i,i,i,i);
    printf("-32768 = %o\t %d\t %u\t %x\n",_i,_i,_i,_i);
    printf(" 32769 = %o\t %d\t %u\t %x\n",maxi,maxi,maxi,maxi);
    printf("-32769 = %o\t\t %d\t %u\t\t %x\n",_maxi,_maxi,_maxi,_maxi);
}

运行结果:
这里写图片描述
解析:
32767(-32769)的二进制
原码:0000 0000 0000 0000 0111 1111 1111 1111
补码:0000 0000 0000 0000 0111 1111 1111 1111
十六进制:0x0000 7FFF

-32767(32769)的二进制
原码:0000 0000 0000 0000 0111 1111 1111 1111
反码:1111 1111 1111 1111 1000 0000 0000 0000
补码:1111 1111 1111 1111 1000 0000 0000 0001
十六进制:0xFFFF 8001

32768的二进制
原码:0000 0000 0000 0000 1000 0000 0000 0000
补码:0000 0000 0000 0000 1000 0000 0000 0000
十六进制:0x0000 8000

-32768的二进制
原码:0000 0000 0000 0000 1000 0000 0000 0000
反码:1111 1111 1111 1111 0111 1111 1111 1111
补码:1111 1111 1111 1111 1000 0000 0000 0000
十六进制:0xFFFF 8000
unsigned short类型为两个字节,取值范围为0~2^16-1,即0~65535

#include<stdio.h>
void main()
{
    unsigned short i = 65535;
    unsigned short _i = -65535;
    unsigned short maxi = 65536;
    unsigned short _maxi = -65536;
    unsigned short mini = 65534;
    unsigned short _mini = -65534;
    printf("  数值 = 无符号八进制 有符号十进制 无符号十进制 无符号十六进制\n");
    printf(" 65534 = \t%o\t %d\t\t %u\t %x\n",mini,mini,mini,mini);
    printf("-65534 = \t%o\t %d\t\t %u\t %x\n",_mini,_mini,_mini,_mini);
    printf(" 65535 = \t%o\t %d\t\t %u\t %x\n",i,i,i,i);
    printf("-65535 = \t%o\t %d\t\t %u\t %x\n",_i,_i,_i,_i);
    printf(" 65536 = \t%o\t %d\t\t %u\t %x\n",maxi,maxi,maxi,maxi);
    printf("-65536 = \t%o\t %d\t\t %u\t %x\n",_maxi,_maxi,_maxi,_maxi);
}

运行结果:
这里写图片描述

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值