七个例子理解整形数据在每个比特位上的存放规则

为了顺利理解这七个例子,以下内容必须清楚:
1.整形数据以补码的形式存放,C语言的整型包括char,short, int,long
2.整型提升
在整型数参与的算术运算过程中,所有的整型数会被转换成整数的形式(一般为int)。如果int无法容纳原数据类型的所有值,那么会转换成unsigned int来处理
3.整型提升的规则:

若是有符号数,则前面8*3位补符号位
若是无符号数,则前面面8*3位补0

4.用char类型可存放的整数范围
在这里插入图片描述所以char类型可存放的整数范围为-128~127

理解后再看这几个例子

//输出什么?
#include <stdio.h>
int main()
{
    char a= -1;
    signed char b=-1;
    unsigned char c=-1;
    printf("a=%d,b=%d,c=%d",a,b,c);
    return 0; 
}

运行结果:
在这里插入图片描述
-1的
原码:10000000 00000000 00000000 00000001
反码:11111111 11111111 11111111 11111110
补码:11111111 11111111 11111111 11111111
char类型只能存放低8个比特位 11111111
题目以整形打印,发生整型提升,根据整型提升规则
a,b都提升为11111111 11111111 11111111 11111111
而c提升为00000000 00000000 00000000 11111111
这些都是补码,对应的就是 -1 -1 255

#include <stdio.h>
int main()
{
    char a = -128;
    printf("%u\n",a);
    return 0;
}

#include <stdio.h>
int main()
{
    char a = 128;
    printf("%u\n",a);
    return 0; }

②③的运行结果都是下图数字
在这里插入图片描述
-128的
原码:10000000 00000000 00000000 10000000
反码: 111111111 11111111 11111111 01111111
补码:111111111 11111111 11111111 10000000
128的
原码:00000000 00000000 00000000 10000000
反码:011111111 11111111 11111111 01111111
补码:011111111 11111111 11111111 10000000
低8个bit位存放在char中 10000000
以无符号整型打印,整型提升为00000000 00000000 00000000 10000000
此补码对应的数据就是上图数据

#include <stdio.h>
int main()
{
	int i = -20;
	unsigned  int  j = 10;
	printf("%d\n", i + j);
}

在这里插入图片描述
-20的
原码:10000000 00000000 00000000 00010100
反码:11111111 11111111 11111111 11101011
补码:11111111 11111111 11111111 11101100
10的
原反补码:00000000 00000000 00000000 00001010
两补码相加得
11111111 11111111 11111111 11110110
以整型打印
以上补码减一:
11111111 11111111 11111111 11110101
取反:
10000000 00000000 00000000 00001010
即为-10

int main()
{
    char a[1000];
    int i;
    for(i=0; i<1000; i++)
   {
        a[i] = -1-i;
   }
    printf("%d",strlen(a));
    return 0; 
}

在这里插入图片描述

char类型可存储的整数范围为-128~127
上例依次存入-1 -2 …… -128 ,当想要存放-129时
-129的
原码:10000000 00000000 00000000 10000001
反码:11111111 11111111 11111111 01111110
补码:11111111 11111111 11111111 01111111
存放低8个bit位 01111111,因此想存放-129时候实际存入127,之后依次存入126~0
所以存入的为-1 , -2 …… -128, 127 …… 1 , 0
长度为128+127=255

#include <stdio.h>
unsigned char i = 0;
int main()
{
    for(i = 0;i<=255;i++)
   {
        printf("hello world\n");
   }
    return 0; 
}

此例结果为死循环,因为无符号的char存放整数时 范围为0~255
当存放255时为11111111
再加一变为00000000
陷入死循环

#include <stdio.h>
int main()
{
	unsigned int i;
	for (i = 9; i >= 0; i--) 
	{
		printf("%u\n", i);
	}
}

此例运行结果也为死循环,因为无符号的数始终大于等于0!

  • 7
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

江南无故人

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值