【C语言】数据存储

本文详细介绍了计算机整型的原码、反码和补码表示,以及为何选择补码;讨论了大端和小端存储模式的区别,并通过示例说明整型提升和截断的概念及其在编程中的应用。
摘要由CSDN通过智能技术生成

 

目录

 

1、整型

1.1原码、反码、补码

1.2为什么要有补码

2、大小端判断(****)

1.1大小端介绍

1.2大小端判断

3、整型提升和截断(以前考得较多)

3.1 概念

3.2练习


1、整型

1.1原码、反码、补码

计算机中的整数有三种2进制表示方法,即原码、反码和补码。

三种表示方法均有符号位和数值位两部分,符号位都是用0表示“正”,用1表示“负”,而数值位 正数的原、反、补码都相同。 负整数的三种表示方法各不相同。

原码

直接将数值按照正负数的形式翻译成二进制就可以得到原码。

反码

将原码的符号位不变,其他位依次按位取反就可以得到反码。

补码

反码+1就得到补码。

对于整形来说:数据存放内存中其实存放的是补码

1.2为什么要有补码

在计算机系统中,数值一律用补码来表示和存储。

原因在于,使用补码,可以将符号位和数值域统 一处理;

同时,加法和减法也可以统一处理(CPU只有加法器);

此外,补码与原码相互转换,其运算过程 是相同的,不需要额外的硬件电路。

2、大小端判断(****)

1.1大小端介绍

大端(存储)模式,是指数据的低位保存在内存的高地址中,而数据的高位,保存在内存的低地址 中;

小端(存储)模式,是指数据的低位保存在内存的低地址中,而数据的高位,,保存在内存的高地 址中。

1.2大小端判断

 #include <stdio.h>
 int check_sys()
 {
     int i = 1;
     return (*(char *)&i);
 }
 int main()
 {
     int ret = check_sys();
     if(ret == 1)
     {
         printf("小端\n");
     }
     else
     {
         printf("大端\n");
     }
     return 0;
 }

3、整型提升和截断(以前考得较多)

3.1 概念

截断是将所占字节大的元素赋给所占字节小的元素时会出现数值的舍去现象;提升是将占字节小的元素赋给占字节大的元素时出现的补位现象。 

补位规则:
提升补高位,无符号数补0,有符号数补符号位

3.2练习

练习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;
}

%d打印有符号的整型

练习2

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

 

%u打印无符号的整型

练习3

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

//-1 -2 -3 -4 -5 .. -128 127 126 .... 5 4 3 2 1 0 -1 -2 ...

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值