计算机中数据的存储(C语言)

简介: 计算机中数据的存储(C语言)

      了解数据在计算机中的存储方式,有助于我们更好的理解计算机与编程,从内部理解掌握计算机的原理,今天就聊一聊数据在计算机中的存储。

   一、数据的基本类型

       C语言中,数据主要有以下五种。

       1.  整型(有符号与无符号)

          (1)有符号:(signed)char,  (signed)short, (signed)int, (signed)long, (signed)long  long.

            (2)   无符号:unsigned  char,  unsigned  short,  unsigned int ,   unsigned long, unsigned long  long.

        2.  浮点型

             (1)有符号: (signed) float,  (signed)  double.

               (2)   无符号: unsigned  float,  unsigned  double.

        3.  构造类型(结构体, 枚举, 联合,注意数组在一定程度上也属于构造类型)    

        4.  指针类型

        5.  空类型(如函数调用中的void, 指针中的NULL)

       下面就最常用的整型及浮点型在内存中的存储作以详细的介绍。

       计算机中表示整型的方式有三种:原码,反码,补码。其中,原码是直接将整型数据转换成二进制之后的表示方式,而反码是指原码的符号位(通常二进制表示的最高位为符号位,0表示正,1表示负)不变,其余按位取反而得到,补码是在反码的基础上加1。

      注意:数据在计算机中均是以补码形式存储的,而我们直接翻译数据得到的是原码, 所以我们经常需要在原码与补码之间相互转换。其中,对于有符号整型及无符号无符号整型具体存储如下:无符号整型三码相同,有符号整型中正数三码相同,只有负数需要相互转换!bu

     至于为什么要有反码与补码,这与硬件电路有关,这里不做叙述。

    下面介绍计算机中数据存储的另一个重要原则:大端字节序与小端字节序存储。

    数据一般是以字节为最小单位的,如char类型为1个字节,int类型为4个字节,这就涉及到放到内存中的顺序问题,我们知道,内存其实就是一系列 的地址,那么在存放数据时数据的地位是存放在低地址还是高地址处呢?其实都有可能。这就是大小端字节序分类的由来。

    大端字节序:是指数据的低位存储在地址的高位中,而数据的高位存储在地址的低位。

    小端字节序:是指数据的低位存储在地址的低位中,而数据的高位存储在地址的高位。

   

    最后介绍一下浮点型在内存中的存储,根据国际标准IEEE(电气和电子工程协会) 754  规定,浮点型数据的存储可表示成如下形式:

           (-1)^S * M * 2^E。

           (-1)^s表示符号位,当s=0,正数;当s=1,负数。

           M表示有效数字,大于等于1,小于2。

           2^E表示指数位。

    在32为平台中,S占一个字节,M占23个字节,E占8个字节;而在64位平台中,S占一个字节,M占52个字节,E占11个字节。其具体分布为S--E--M,及先是S,然后是E,最后是M。

    由于M均为1.XXXXX,所以在存储时会将1舍去,仅存储小数点后的数字,这样就可以多存一位,精度更高,只是注意在读取时不要忘了将那个1加上。

    而E就会比较复杂,首先,它是一个无符号整型,但我们都知道,指数是可以为负的,所以E具体存储时会加上一个正数(32位平台加127,64位平台加1023),这样就能解决问题了,同样的,在读取时要记得减去相应的数字。

   在具体读取浮点数时右分为三种情况:

          1. E全为0(补码),这是浮点数趋近无穷小,我们就认为是0.

          2. E全为1(补码),这是浮点数趋近无穷大.

          3. E不全为0,也不全为1,这时正常读取就可以了。

   好了,以上就是关于数据存储的相关内了,水平有限,还请大家相互交流,相互学习。

相关文章
|
11天前
|
存储 程序员 编译器
C 语言中的数据类型转换:连接不同数据世界的桥梁
C语言中的数据类型转换是程序设计中不可或缺的一部分,它如同连接不同数据世界的桥梁,使得不同类型的变量之间能够互相传递和转换,确保了程序的灵活性与兼容性。通过强制类型转换或自动类型转换,C语言允许开发者在保证数据完整性的前提下,实现复杂的数据处理逻辑。
|
11天前
|
存储 数据管理 C语言
C 语言中的文件操作:数据持久化的关键桥梁
C语言中的文件操作是实现数据持久化的重要手段,通过 fopen、fclose、fread、fwrite 等函数,可以实现对文件的创建、读写和关闭,构建程序与外部数据存储之间的桥梁。
|
15天前
|
存储 数据建模 程序员
C 语言结构体 —— 数据封装的利器
C语言结构体是一种用户自定义的数据类型,用于将不同类型的数据组合在一起,形成一个整体。它支持数据封装,便于管理和传递复杂数据,是程序设计中的重要工具。
|
21天前
|
存储 编译器 数据处理
C 语言结构体与位域:高效数据组织与内存优化
C语言中的结构体与位域是实现高效数据组织和内存优化的重要工具。结构体允许将不同类型的数据组合成一个整体,而位域则进一步允许对结构体成员的位进行精细控制,以节省内存空间。两者结合使用,可在嵌入式系统等资源受限环境中发挥巨大作用。
46 11
|
2月前
|
存储 C语言 C++
深入C语言,发现多样的数据之枚举和联合体
深入C语言,发现多样的数据之枚举和联合体
深入C语言,发现多样的数据之枚举和联合体
|
2月前
|
存储 C语言
深入C语言内存:数据在内存中的存储
深入C语言内存:数据在内存中的存储
|
2月前
|
C语言
回溯入门题,数据所有排列方式(c语言)
回溯入门题,数据所有排列方式(c语言)
|
存储 程序员 C语言
程序员之路:C语言中存储类别
程序员之路:C语言中存储类别
136 0
|
10天前
|
存储 C语言 开发者
【C语言】字符串操作函数详解
这些字符串操作函数在C语言中提供了强大的功能,帮助开发者有效地处理字符串数据。通过对每个函数的详细讲解、示例代码和表格说明,可以更好地理解如何使用这些函数进行各种字符串操作。如果在实际编程中遇到特定的字符串处理需求,可以参考这些函数和示例,灵活运用。
29 10
|
10天前
|
存储 程序员 C语言
【C语言】文件操作函数详解
C语言提供了一组标准库函数来处理文件操作,这些函数定义在 `<stdio.h>` 头文件中。文件操作包括文件的打开、读写、关闭以及文件属性的查询等。以下是常用文件操作函数的详细讲解,包括函数原型、参数说明、返回值说明、示例代码和表格汇总。
28 9