C语言进阶⑩(数据的存储)数据类型_介绍+存储_大小端(知识点+笔试题)(上)

简介: C语言进阶⑩(数据的存储)数据类型_介绍+存储_大小端(知识点+笔试题)

本章重点

1. 数据类型详细介绍

2. 整形在内存中的存储:原码、反码、补码

3. 大小端字节序介绍及判断

4. 浮点型在内存中的存储解析


前面我们已经学习了基本的内置类型:

以及他们所占存储空间的大小。

1. 数据类型介绍

前面我们已经学习了基本的内置类型:

char //字符数据类型

short //短整型

int //整形

long //长整型

long long //更长的整形

float //单精度浮点数

double //双精度浮点数

类型的意义:

1. 使用这个类型开辟内存空间的大小(大小决定了使用范围)。

2. 如何看待内存空间的视角。

1.1 类型的基本归类:

整形家族:


为什么 char 算整型:因为字符类型底层存储的是 ASCII 码值,而ASCII码值也是整数,所以在归类的时候会把 char 类型归结到整型家族里去。( ASCII码: 美国信息交换标准代码

浮点数家族:


构造类型:(自定义类型)

注意事项:如下面数组都是整型数组,但是它们的类型完全不一样

 
int arr1[10]; // 类型为:int[10]
int arr2[5]; // 类型为:int[5] 

指针类型

空类型:

void 表示空类型(无类型)

通常应用于函数的返回类型、函数的参数、指针类型。

2.整形在内存中的存储

看看内存:

2.1原码、反码、补码

数据在内存中以2进制的形式存储:

① 对于整数来说,内存中存储的二进制有3种表示形式:原码、反码、补码。

② 正整数:原码、反码、补码相同。

③ 负整数:原码、反码、补码不同,要进行计算。

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

符号位:最高位1表示负数,最高位0表示正数


负整数反码:原码的符号位不变,其他位按位取反,即为反码

负整数补码:反码 +1,得到的就是补码

2.1.1 内存中为何存放补码

虽然整数的二进制表示形式有三种,但是内存中存储的是补码

为什么在内存中存的是补码呢:

在计算机系统中,整数数值一律用补码来表示和存储。原因在于,使用补码,可以将符号位和数字域统一处理;同时,加法和减法也可以统一处理( CPU只有加法器 )。此外,补码与补码相互转换,其运算过程是相同的,不需要额外的硬件电路


2.2大小端介绍

再仔细观察下刚才内存中的存储,这次再添加一个 b = 10:

可以看到对于 a 和 b 分别存储的是补码,

但是发现顺序好像是倒过来的,为什么会这样呢?

大端小端存储问题,当一个数据的大小存储到内存空间大于1个字节时,会存在一个存储顺序的问题,这个存储顺序的问题就有两种,一个为大端,一个为小端。

2.2.1大端模式

作用:把数据的低位保存在内存的高地址处,高位字节序的内容存放在低地址中(正着存)

总结:大端模式,低位放在高地址,高位放在低地址

2..2.2小端模式

作用:把数据的低位保存在内存的低地址处,高位字节序的内容存放在高地址中(倒着存)

总结:小端模式,低位放在低地址,高位放在高地址

2.2.3产生的原因

为什么会有大小端模式之分呢?这是因为在 计算机系统中,是以字节为单位的,

每个地址单元都对应着一 个字节,一个字节为8bit。但是在C语言中除了8bit的char之外,

还有16bit的short型,32bit的long型(要看具体的编译器),另外,对于位数大于8位的处理器,例如16位或者32位的处理器,由于寄存器宽度大于一个字节,

那么 必然存在着一个如何将多个字节安排的问题。正是因为 不同的安排顺序导致了 大端存储模式和 小端存储模式的存在。


例如一个 16bit 的 short 型 x ,在内存中的地址为 0x0010 , x 的值为 0x1122 ,

那么 0x11 为高字节, 0x22 为低字节。对于大端模式,就将 0x11 放在低地址中

即 0x0010 中, 0x22 放在高地址中,即 0x0011 中。小 端模式,刚好相反。

我们常用的 X86 结构是小端模式,而 KEIL C51 则为大端模式。很多的ARM,DSP都为小 端模式。

有些ARM处理器还可以由硬件来选择是大端模式还是小端模式。

2.2.4代码判断大小端

百度_系统工程师笔试题:请简述大端字节序和小端字节序的概念,设计一个小程序来判断当前机器的字节序。

直接放代码:

 
#include<stdio.h>
int check_sys()
{
    int i = 1;
    char* p = (char*)&i; // 取第一个字节
    return *p; // 返回1表示小端(01 00 00 00),返回0表示大端(00 00 00 01)
}
int main()
{
    if (check_sys)
    {
        printf("小端\n");
    }
    else
    {
        printf("大端\n");
    }
    return 0;
}

d77c8439052a4083b6aab0a52ae9b2e5.png


C语言进阶⑩(数据的存储)数据类型_介绍+存储_大小端(知识点+笔试题)(中):https://developer.aliyun.com/article/1513036

目录
相关文章
|
15天前
|
存储 编译器 C语言
C语言存储类详解
在 C 语言中,存储类定义了变量的生命周期、作用域和可见性。主要包括:`auto`(默认存储类,块级作用域),`register`(建议存储在寄存器中,作用域同 `auto`,不可取地址),`static`(生命周期贯穿整个程序,局部静态变量在函数间保持值,全局静态变量限于本文件),`extern`(声明变量在其他文件中定义,允许跨文件访问)。此外,`typedef` 用于定义新数据类型名称,提升代码可读性。 示例代码展示了不同存储类变量的使用方式,通过两次调用 `function()` 函数,观察静态变量 `b` 的变化。合理选择存储类可以优化程序性能和内存使用。
135 82
|
17天前
|
存储 人工智能 C语言
数据结构基础详解(C语言): 栈的括号匹配(实战)与栈的表达式求值&&特殊矩阵的压缩存储
本文首先介绍了栈的应用之一——括号匹配,利用栈的特性实现左右括号的匹配检测。接着详细描述了南京理工大学的一道编程题,要求判断输入字符串中的括号是否正确匹配,并给出了完整的代码示例。此外,还探讨了栈在表达式求值中的应用,包括中缀、后缀和前缀表达式的转换与计算方法。最后,文章介绍了矩阵的压缩存储技术,涵盖对称矩阵、三角矩阵及稀疏矩阵的不同压缩存储策略,提高存储效率。
|
19天前
|
存储 算法 C语言
数据结构基础详解(C语言): 二叉树的遍历_线索二叉树_树的存储结构_树与森林详解
本文从二叉树遍历入手,详细介绍了先序、中序和后序遍历方法,并探讨了如何构建二叉树及线索二叉树的概念。接着,文章讲解了树和森林的存储结构,特别是如何将树与森林转换为二叉树形式,以便利用二叉树的遍历方法。最后,讨论了树和森林的遍历算法,包括先根、后根和层次遍历。通过这些内容,读者可以全面了解二叉树及其相关概念。
|
19天前
|
存储 机器学习/深度学习 C语言
数据结构基础详解(C语言): 树与二叉树的基本类型与存储结构详解
本文介绍了树和二叉树的基本概念及性质。树是由节点组成的层次结构,其中节点的度为其分支数量,树的度为树中最大节点度数。二叉树是一种特殊的树,其节点最多有两个子节点,具有多种性质,如叶子节点数与度为2的节点数之间的关系。此外,还介绍了二叉树的不同形态,包括满二叉树、完全二叉树、二叉排序树和平衡二叉树,并探讨了二叉树的顺序存储和链式存储结构。
|
19天前
|
存储 算法 C语言
C语言手撕数据结构代码_顺序表_静态存储_动态存储
本文介绍了基于静态和动态存储的顺序表操作实现,涵盖创建、删除、插入、合并、求交集与差集、逆置及循环移动等常见操作。通过详细的C语言代码示例,展示了如何高效地处理顺序表数据结构的各种问题。
|
16天前
|
存储 Serverless C语言
【C语言基础考研向】11 gets函数与puts函数及str系列字符串操作函数
本文介绍了C语言中的`gets`和`puts`函数,`gets`用于从标准输入读取字符串直至换行符,并自动添加字符串结束标志`\0`。`puts`则用于向标准输出打印字符串并自动换行。此外,文章还详细讲解了`str`系列字符串操作函数,包括统计字符串长度的`strlen`、复制字符串的`strcpy`、比较字符串的`strcmp`以及拼接字符串的`strcat`。通过示例代码展示了这些函数的具体应用及注意事项。
|
19天前
|
存储 C语言
C语言程序设计核心详解 第十章:位运算和c语言文件操作详解_文件操作函数
本文详细介绍了C语言中的位运算和文件操作。位运算包括按位与、或、异或、取反、左移和右移等六种运算符及其复合赋值运算符,每种运算符的功能和应用场景都有具体说明。文件操作部分则涵盖了文件的概念、分类、文件类型指针、文件的打开与关闭、读写操作及当前读写位置的调整等内容,提供了丰富的示例帮助理解。通过对本文的学习,读者可以全面掌握C语言中的位运算和文件处理技术。
|
19天前
|
存储 C语言
C语言程序设计核心详解 第七章 函数和预编译命令
本章介绍C语言中的函数定义与使用,以及预编译命令。主要内容包括函数的定义格式、调用方式和示例分析。C程序结构分为`main()`单框架或多子函数框架。函数不能嵌套定义但可互相调用。变量具有类型、作用范围和存储类别三种属性,其中作用范围分为局部和全局。预编译命令包括文件包含和宏定义,宏定义分为无参和带参两种形式。此外,还介绍了变量的存储类别及其特点。通过实例详细解析了函数调用过程及宏定义的应用。