整型数据存储

//代码1
#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;
}
     1000 0000 0000 0001 -> -1源码
    1111 1111 1111 1110 -> -1反码
    1111 1111 1111 1111 -> -1补码
    对于a,按位提升,看的是当前比特位的类型,所以按位提升将变为1111 1111 1111 1111 1111 1111 1111 1111,而输出的时候先看类型和最高位,类型是有符号char,由于最高位是1,所以必须将此时的补码1111 1111转换为源码,在进行读取,此时对应的源码是1000 0001,对应的二进制数字是-1,对于b,输出的和a是一样的,这里不在多说。而对于c来说,它对应的当前变量的类型是无符号char类型,而读的时候是以%d的形式输出,所以将1111 1111转换为二进制,对应的数字是255,所以输出的结果如图所示。这里写图片描述
//代码2
#include<stdio.h>
int main()
{
    char a = -128;
    printf("%u\n", a);
    return 0;
}
    -128对应的二进制比特为是1000 0000,当以%u的形式输出的时候,先进行比特位按位提升,1111 1111 1111 1111 1111 1111 1000 0000,按照%u输出就会成为一个特别大的数字
//代码3
#include<stdio.h>
int main()
{
    char a = 128;
    printf("%u\n", a);
    return 0;
}
    128对应的二进制比特位是1000 0000,它的类型是有符号char类型,输出以%u输出,此时先进行比特位提升1111 1111 1111 1111 1111 1111 1000 0000,而输出是以%u输出,此时应该是一个非常大的数

这里写图片描述

//代码4
#include<stdio.h>
int main()
{
    int i = -20;
    unsigned int j = 10;
    printf("%d\n", i + j);
    return 0;
}
    i对应的二进制补码是1111 1111 1111 1111 1111 1111 1110 1100 ,10是无符号整型,对应的二进制是0000 0000 0000 0000 0000 0000 0000 1010,将i和j相加得到1111 1111 1111 1111 1111 1111 1111 0110,输出是以%d的形式输出,则将二进制对应的补码转换为原码是1000 0000 0000 0000 0000 0000 0000 1010,将其输出对应的十进制数是-10

这里写图片描述

//代码5
#include<stdio.h>
int main()
{
    unsigned i;
    for (i = 9; i >= 0; i--)
    {
        printf("%u\n", i);
    }
    return 0;
}
     这里的i是一个无符号int型数据,所以在它的眼里所有的数据都是大于零的,所以程序自然会进入死循环中
//代码6
#include<stdio.h>
#include<string.h>
int main()
{
    char a[1000];
    int i;
    for (i = 0; i < 1000; i++)
    {
        a[i] = -1 - i;
    }
    printf("%d", strlen(a));
    return 0;
}
    a[i]先是由-1到-128;当i变成128时此时-1-128赋值给a[i],而a[i]是一个有符号char类型,此时-1和-128相加,在a[i]的眼里将变成127, 继续加则是126,直到0,则对应的字符有128 + 128 = 256,但是字符串是以’\0’结尾,此时的0将不算入其中,则总共有255个字符

这里写图片描述

//代码7
#include<stdio.h>
int main()
{
    short num = 32767;
    short int a = num + 1;
    printf("%d", a);
    return 0;
}

这里写图片描述

    32767对应的二进制原码是0111 1111 1111 1111,当给其加1时变成 1000 0000 0000 0000,然后以%d输出,先进行符号扩展,a是有符号短整型,符号扩展为1111 1111 1111 1111 1000 0000 0000 0000,而符号位是1,转换为原码是1000 0000 0000 0000 1000 0000 0000 0000,所以输出是-32769
//代码8
#include<stdio.h>
unsigned char i = 0;
int main()
{
    for (i = 0; i <= 255; i++)
    {
        printf("hello, world\n");
    }
    return 0;
}
    i的类型是无符号char,范围是0到255,所以死循环
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值