关于C语言中数据在内存中的存储详解

前言

1. 数据类型详细介绍

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

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

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

一、数据类型介绍

1.类型的基本归类

1.整形家族

char
unsigned char
signed char
short
unsigned short [int]
signed short [int]
int
unsigned int
signed int
long
unsigned long [int]
signed long [int]

2.浮点型家族

float
double

3.构造类型

数组类型
结构体类型 struct
枚举类型 enum
联合类型 union

4.指针类型

int pi;
char pc;
float
pf;
void
pv;

5.空类型

void 表示空类型(无类型)
通常应用于函数的返回类型、函数的参数、指针类型

二、整型在内存中的存储

1.原码、反码、补码

计算机中的有符号数有三种表示方法,即原码、反码和补码。
三种表示方法均有符号位和数值位两部分,符号位都是用0表示“正”,用1表示“负”,而数值位
三种表示方法各不相同。
原码:
直接将二进制按照正负数的形式翻译成二进制就可以。
反码:
将原码的符号位不变,其他位依次按位取反就可以得到了。

代码如下:

#define _CRT_SECURE_NO_WARNINGS   1
#include<stdio.h>
int main()
{
	int a = 20;                //00000000 00000000 00000000 00010100  20的原码、反码、补码相同

	int b = -10;               //10000000 00000000 00000000 00001010  10的原码
    printf("%d\n", a + b);     //11111111 11111111 11111111 11110101  10的反码

	return 0;                  //11111111 11111111 11111111 11110110  10的补码
}                              //00000000 00000000 00000000 00010100  20的补码
                              //100000000 00000000 00000000 00001010  两者相加,因为int只有32位丢掉最前面的

2.内存中怎样存储


3.大小端字节序

1.大端小端的概念

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

2.大小端字节序的由来

为什么会有大小端模式之分呢?这是因为在计算机系统中,我们是以字节为单位的,每个地址单元都对应着一个字节,一个字节为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处理器还可以由硬件来选择是大端模式还是小端模式。

3.判断系统是大端还是小端

代码如下:

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

4.整形存储的典型例题

代码如下:

#define _CRT_SECURE_NO_WARNINGS   1
#include<stdio.h>
int main()
{
	char a = -1;                              //10000000 00000000 00000000 000000001  -1的原码
	signed char b = -1;                       //11111111 11111111 11111111 111111110  -1的反码
	unsigned char c = -1;                     //11111111 11111111 11111111 111111111  -1的补码
	printf("a=%d,b=%d,c=%d", a, b, c);        //因为a是字符类型,所以发生截断 111111111
	return 0;                                 //%d打印十进制,所以发生整形提升,按符号位来提升
}                                             //11111111 11111111 11111111 11111111  -1的补码,所以原码为-1
                                              //对于unsigned char来说      11111111 中1不是符号位所以高位补0
                                              //00000000 00000000 00000000 11111111 所以为正数,原、反、补相同为255

代码如下:

int main()
{
	char a = -128;                           //10000000 00000000 00000000 10000000  128的原码
	printf("%u\n", a);                       //11111111 11111111 11111111 01111111  128的反码
}                                            //11111111 11111111 11111111 10000000  128的补码
                                             //因为a是字符类型,所以发生截断 10000000 a的值
                                             //%u是打印无符号整形,所以发成整形提升
                                             //11111111 11111111 11111111 10000000
                                             //%u是无符号整形,所以原码、反码、补码相同

代码如下:

int main()
{
	char a = 128;                           //00000000 00000000 00000000 10000000  128的原码
	printf("%u\n", a);                      //01111111 11111111 11111111 01111111  128的反码
}                                           //01111111 11111111 11111111 10000000  128的补码
                                            //因为a是char类型,所以发生截断 10000000 -a
                                            //%u是打印无符号整形,所以发生整形提升,因为是char类型,所以高位是符号位
                                            //11111111 11111111 11111111 100000000
                                            //%u是无符号整形,所以原码、反码、补码相同

代码如下:

int main()
{
	int i = -20;                            //10000000 00000000 00000000 00010100  -20的原码
	unsigned int j = 10;                    //11111111 11111111 11111111 11101011  -20的反码
	printf("%d\n", i + j);                  //11111111 11111111 11111111 11101100  -20的补码
}                                           //00000000 00000000 00000000 00001010  10的原码、反码、补码
                                            //11111111 11111111 11111111 11110110  相加为补码
                                            //11111111 11111111 11111111 11110101   反码
                                            //10000000 00000000 00000000 00001010   补码  为-10

代码如下:

#define _CRT_SECURE_NO_WARNINGS   1
#include<stdio.h>
#include<Windows.h>
int main()
{
	unsigned int i = 0;           //此时打印完9 8 7 6 5 4 3 2 1 0减减为-1是无符号在内存中补码是全部为1,i恒大于0
	for (i = 9; i >= 0; i--)
	{
		printf("%u \n", i);
		Sleep(1000);
	}
	return 0;
}

代码如下:

#define _CRT_SECURE_NO_WARNINGS   1
#include<stdio.h>
#include<Windows.h>
int main()
{
	unsigned int i = 0;           //此时打印完9 8 7 6 5 4 3 2 1 0减减为-1是无符号在内存中补码是全部为1,i恒大于0
	for (i = 9; i >= 0; i--)
	{
		printf("%u \n", i);
		Sleep(1000);
	}
	return 0;
}

代码如下:

unsigned char i = 0;
int main()
{
	for (i = 0; i <= 255; i++)     //死循环的打印bit,因为unsigned char取值范围是0-255,所以for循环永远成立
	{
		printf("bit\n");
	}
	return 0;
}

三、浮点型在内存中的存储

1.浮点型怎么存储

根据国际标准IEEE(电气和电子工程协会) 754,任意一个二进制浮点数V可以表示成下面的形式:
1.(-1)^S * M * 2^E
(-1)^s表示符号位,当s=0,V为正数;当s=1,V为负数。
2.M表示有效数字,大于等于1,小于2。
3.2^E表示指数位。
举例来说: 十进制的5.0,写成二进制是 101.0 ,相当于 1.01×2^2 。 那么,按照上面V的格式,可以得出s=0,M=1.01,E=2。
十进制的-5.0,写成二进制是 -101.0 ,相当于 -1.01×2^2 。那么,s=1,M=1.01,E=2。
IEEE 754规定: 对于32位的浮点数,最高的1位是符号位s,接着的8位是指数E,剩下的23位为有效数字M

2.浮点型存储例题

代码如下:

#define _CRT_SECURE_NO_WARNINGS   1
#include<stdio.h>
int main()
{
	int n = 9;
	float* pFloat = (float*)&n;
	printf("n的值为:%d\n", n);
	printf("*pFloat的值为:%f\n", *pFloat);

	*pFloat = 9.0;
	printf("num的值为:%d\n", n);
	printf("*pFloat的值为:%f\n", *pFloat);
	return 0;
}

总结

以上就是今天要讲的内容,本文仅仅简单介绍了数据整形和浮点型在内存中的存储,了解这个更能令我们了解数据怎么在内存中存储。另外,如果上述有任何问题,请懂哥指教,不过没关系,主要是自己能坚持,更希望有一起学习的同学可以帮我指正,但是如果可以请温柔一点跟我讲,爱与和平是永远的主题,爱各位了。

到此这篇关于关于C语言中数据在内存中存储的文章就介绍到这了,更多相关C语言数据在内存的存储内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • C语言数据(整数、浮点数)在内存中的存储

    本篇主要讨论:整数.浮点数在内存中是怎么保存的! 数据类型详细介绍 在前面C语言基础概览中,已经提到过了基本的C语言内置类型,但C语言的数据类型有无数种~ 但是可以把这些类型分为几个大类: 类型的归类: 存整数的 char,short,int,long,long long及所配套的unsigned,int*,int[]- 2.存浮点数的 float,double,float[]- 结构体(结构体在内存中的存储后面在进行讨论~) 整数在内存种的存储: 1.字节序 2.补码 内存窗口 调试模式下的内

  • 关于C语言中数据在内存中的存储详解

    前言 1. 数据类型详细介绍 2. 整形在内存中的存储:原码.反码.补码 3. 大小端字节序介绍及判断 4. 浮点型在内存中的存储解析 一.数据类型介绍 1.类型的基本归类 1.整形家族 char unsigned char signed char short unsigned short [int] signed short [int] int unsigned int signed int long unsigned long [int] signed long [int] 2.浮点型家族

  • C语言编程数据在内存中的存储详解

    目录 变量在计算机中有三种表示方式,原码反码,补码 原码 反码 补码 总结一下 浮点数在内存的储存 C语言中,有几种基本内置类型. int unsigned int signed int char unsigned char signed char long unsigned long signed long float double 在内存中创建变量,会在内存中开辟空间,并为其赋值. int a=10; 在计算机中,所有数据都是以二进制的形式存储在内存中. 变量在计算机中有三种表示方式,原码反

  • C语言实现txt数据读入内存/CPU缓存实例详解

    摘要 C实现将txt数据读入内存/CPU缓存的函数,不多说,实现如下. 1. 实现代码 #include "stdafx.h" #include <stdio.h> #include <stdlib.h> int filelength(FILE *fp); char *readfile(char *path); int main(void){ char *string; string=readfile("C:/Users/Joe WANG/Deskto

  • python中数据爬虫requests库使用方法详解

    一.什么是Requests Requests 是Python语编写,基于urllib,采Apache2 Licensed开源协议的 HTTP 库.它urllib 更加方便,可以节约我们大量的工作,完全满足HTTP测试需求. 一句话--requests是python实现的简单易用的HTTP库 二.安装Requests库 进入命令行win+R执行 命令:pip install requests 项目导入:import requests 三.各种请求方式 直接上代码,不明白可以查看我的urllib的基

  • C语言 以数据块的形式读写文件详解及实现代码

    fgets() 有局限性,每次最多只能从文件中读取一行内容,因为 fgets 遇到换行符就结束读取.如果希望读取多行内容,需要使用 fread 函数:相应地写入函数为 fwrite. fread() 函数用来从指定文件中读取块数据.所谓块数据,也就是若干个字节的数据,可以是一个字符,可以是一个字符串,可以是多行数据,并没有什么限制.fread() 的原型为: size_t fread ( void *ptr, size_t size, size_t count, FILE *fp ); fwri

  • C语言详细分析不同类型数据在内存中的存储

    目录 数据类型的介绍 类型的基本归类 整形在内存中的存储 大小端介绍 一道笔试题 浮点数在内存中的存储 浮点数存储规则 剖析题目 数据类型的介绍 在我们之前的学习当中我们已经介绍了基本的内置类型 char 字符数据类型 short 短整型 int 整形 long 长整型 long long 更长的整形 float 单精度浮点数 double 双精度浮点数 这些类型的意义是: 1.使用这个类型开辟内存空间的大小,大小决定了使用范围 2.如何看待内存空间的视角. 类型的基本归类 整形 整形中分为有符

  • C语言数据在内存中的存储流程深入分析

    目录 前言 类型的基本分类 整型 浮点数 自定义类型 整型在内存中的存储 原码.反码.补码 大端和小端 如何判断编译器是大端还是小端 浮点数在内存中的存储 总结 前言 C语言中有char.short.int.long.long long.float和doubole这些数据类型.这些数据类型也叫内置类型. 所占存储空间的大小: 数据类型 所占存储空间的大小 char 1个字节 int 4个字节 short 4个字节 long 4个字节 long long 32位平台下占4个字节 ,64位平台下占8

  • C++浅析数据在内存中如何存储

    目录 一.数据类型 二.原码反码补码 三.大小端 整型提升 一.数据类型 数据类型有7种: char            字符型     short          短整型    int               整型   long            长整型   long long    更长整型   float            单精度浮点数    double        双精度浮点数 二.原码反码补码 计算机中的整数有三种2进制表示方法,即原码.反码和补码. 三种表示方法均

  • R语言中矩阵matrix和数据框data.frame的使用详解

    本文主要介绍了R语言中矩阵matrix和数据框data.frame的一些使用,分享给大家,具体如下: "一,矩阵matrix" "创建向量" x_1=c(1,2,3) x_1=c(1:3) x_2=1:3 typeof(x_1)==typeof(x_2)#查看目标类型 x_3=seq(1,6,length=3)#将1--6分为3个数 a<-rep(1:3,each=3) #1到3依次重复 c<-rep(1:3,times=3) #1到3重复3次 d<

  • C语言中的指针以及二级指针代码详解

    很多初学者都对C中的指针很迷糊,希望这篇blog能帮助到大家: 1.什么是"指针": 在执行C程序的时候,由于我们的数据是存储在内存中的.所以对于C程序本身来说,如果想找到相应被调用的数据,就要知道存储该数据的内存地址是多少,换言之,C程序通过已知的内存地址到相应的内存位置存储数据. 这里简单说一下内存管理(对于初学者来说.为了避免专业术语引发的理解问题,下面的叙述尽量避免专业定义:),对于现代计算机系统来说,内存空间分为两个区域,一个是"数据区",一个是"

随机推荐