C语言进阶:整型数据的存储

简介: C语言进阶:整型数据的存储

一.整型数据类型介绍

short  :

unsigned short[int]

signed short[int]

int  :

unsigned int

signed int

long  :

unsigned long[int]

signed long[int]

char  :

unsigned  char

signed char

因为char 类型的数据是通过ASCII值存储的,所以也属于整型家族

下表列出了关于标准整数类型的存储大小和值范围的细节:

注意,各种类型的存储大小与系统位数有关,但目前通用的以64位系统为主。

以下列出了32位系统与64位系统的存储大小的差别(windows 相同):

二.整型的存储

数据在内存中以2进制的形式存储,对于整数来说:

1.整数的二进制有三种表示形式:原码,反码,补码。

2.正整数:原码,反码,补码相同;

3.负整数:原码,反码,补码需要计算;

4.计算方法:

按照数据的数值直接写出的二进制序列就是原码;

原码的符号位不变,其它位按位取反得到反码;

反码 + 1 得到补码

注意:数据都是以补码的形式存储的,计算时也是补码之间的运算,打印时按照原码打印。

三.整型提升

1.什么是整型提升:

C的整型算数运算总是至少以缺省整型类型的精度来进行的。为了获得这个精度,表达式中的**字符和短整型操作数( char 属于整型家族 )**在使用之前被转换为普通整型,这种转换称为整型提升。

2.规则:

整型提升是按照变量的数据类型的二进制位符号来提升的,无符号数整型提升高位都补0,有符号数整型提升高位补符号位。

例:

四.算数转换

1.定义:

若某个操作符的各个操作数属于不同的类型,那么在运算时一个操作数的类型转换成另一个操作数的类型;

转换优先级:

long double > double > float >unsigned long int  > long  int   > unsigned int > int > char

注意:转换要合理(从下到上转换),不然会有一些潜在的问题,比如精度丢失

五.大端字节序和小端字节序

1.大端字节序:把数据的低位字节序的内容存放在高地址,高位字节序的内容存放在低地址;

2.小端字节序:把数据的低位字节序的内容存放在低地址,高位字节序的内容存放在高地址;

存放在地址中是以16进制形式存放的;

什么是低位字节序,什么是低地址呢?

如图:

可以这么理解,小端字节序是倒着存放的,大端字节序是正着存放的。

我们可以写个代码来判断当前机器是以什么字节序存储的

要想知道是大端还是小端,其实只需要判断第一个字节就行了,为了使判断过程更简单,我们可以定义  int  a=1; 原因如图:

代码实现:

1. int main()
2. {
3.  int a = 1;
4.  char* p = (char*)&a;  //强制类型转换成 char*
5.  if (*p == 1)
6.  {
7.    printf("小端\n");
8.  }
9.  else
10.     printf("大端\n");
11.   return 0;
12. }

六.char 类型的存储问题

首先 char 类型到底是 signed char 还是 unsigned char ,C语言标准并没有规定,这取决于编译器

1. 有符号型 char 的范围:-128 ~ 127

原因如图:

可以这么理解:

巧记口诀:

超出范围的数据如果是整数,则减去256;如果是负数,则加上256。

2.无符号型 char 的范围: 0 ~ 255

例1:

1. #include <stdio.h>
2. 
3. int main()
4. {
5. char a=-1;
6. signed char b=-1;
7. unsigned char c=-1;
8. printf("a=%d,b=%d,c=%d\n",a,b,c);
9. return 0;
10. }

正解:a=-1,b=-1,c=255

a 和 b 很好理解,问题就是c,我们利用上面的巧记口诀,因为 -1 是负数,-1+256=255,所以c=255;那究竟为什么是255呢?请看下图:

例2:

1. #include <stdio.h>
2. 
3. int main()
4. {
5. char a=-128;
6. printf("%u",a);
7. return 0;
8. }

正解:4294967168

解析:

     🐋😼 本篇文章到此就结束啦,如有错误或是建议,欢迎小伙伴们指出。🦖🦄

       😸😽谢谢你的阅读。😻🐼


目录
相关文章
|
2月前
|
存储 编译器 C语言
C语言存储类详解
在 C 语言中,存储类定义了变量的生命周期、作用域和可见性。主要包括:`auto`(默认存储类,块级作用域),`register`(建议存储在寄存器中,作用域同 `auto`,不可取地址),`static`(生命周期贯穿整个程序,局部静态变量在函数间保持值,全局静态变量限于本文件),`extern`(声明变量在其他文件中定义,允许跨文件访问)。此外,`typedef` 用于定义新数据类型名称,提升代码可读性。 示例代码展示了不同存储类变量的使用方式,通过两次调用 `function()` 函数,观察静态变量 `b` 的变化。合理选择存储类可以优化程序性能和内存使用。
152 82
|
27天前
|
存储 C语言 C++
深入C语言,发现多样的数据之枚举和联合体
深入C语言,发现多样的数据之枚举和联合体
深入C语言,发现多样的数据之枚举和联合体
|
29天前
|
存储 C语言
C语言:设置地址为 0x67a9 的整型变量的值为 0xaa66
在C语言中,可以通过指针操作来实现对特定地址的访问和赋值。要将地址为 0x67a9 的整型变量值设为 0xaa66,可以先定义一个指向该地址的指针,并通过该指针对该内存位置进行赋值操作。需要注意的是,直接操作内存地址具有一定风险,必须确保地址合法且可写。代码示例应考虑字节序及内存对齐问题。
|
27天前
|
存储 C语言
深入C语言内存:数据在内存中的存储
深入C语言内存:数据在内存中的存储
|
28天前
|
C语言
回溯入门题,数据所有排列方式(c语言)
回溯入门题,数据所有排列方式(c语言)
|
2月前
|
存储 C语言
【C语言基础考研向】04整型进制转换
本文介绍了计算机中整型常量的不同进制表示,包括二进制、八进制、十六进制和十进制,并解释了它们之间的转换方法。以一个32位整型数为例,展示了其在不同进制下的表示形式及计算方法,特别指出在内存观察中常用十六进制,同时提到了小端存储方式对数据的影响。
|
1月前
|
存储 C语言
C语言中的浮点数存储:深入探讨
C语言中的浮点数存储:深入探讨
|
26天前
|
C语言 C++
C语言 之 内存函数
C语言 之 内存函数
31 3
|
17天前
|
存储 缓存 C语言
【c语言】简单的算术操作符、输入输出函数
本文介绍了C语言中的算术操作符、赋值操作符、单目操作符以及输入输出函数 `printf` 和 `scanf` 的基本用法。算术操作符包括加、减、乘、除和求余,其中除法和求余运算有特殊规则。赋值操作符用于给变量赋值,并支持复合赋值。单目操作符包括自增自减、正负号和强制类型转换。输入输出函数 `printf` 和 `scanf` 用于格式化输入和输出,支持多种占位符和格式控制。通过示例代码详细解释了这些操作符和函数的使用方法。
31 10
|
10天前
|
存储 算法 程序员
C语言:库函数
C语言的库函数是预定义的函数,用于执行常见的编程任务,如输入输出、字符串处理、数学运算等。使用库函数可以简化编程工作,提高开发效率。C标准库提供了丰富的函数,满足各种需求。