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

本篇主要讨论:整数、浮点数在内存中是怎么保存的!

数据类型详细介绍

在前面C语言基础概览中,已经提到过了基本的C语言内置类型,但C语言的数据类型有无数种~ 但是可以把这些类型分为几个大类:

类型的归类:

  1. 存整数的
    char,short,int,long,long long及所配套的unsigned,int*,int[]…
  2. 2.存浮点数的
    float,double,float[]…
  3. 结构体(结构体在内存中的存储后面在进行讨论~)

整数在内存种的存储:

1.字节序

2.补码

内存窗口

调试模式下的内存窗口,若不是调试状态,是打不开内存窗口的,正常情况下,不调试,是没有内存窗口的

char str[]="abc";

这里内存数据只截了部分图,方便清晰观察

内存数据中有很多的"cc cc cc",就是0xcc,其实在Intel的CPU中表示中断指令,VS的debug模式下,会把局部变量的后边填充上0xcc,填充的目的是及时发现下标越界

int num = 0x11223344;

此处就涉及到字节序

字节序

字节序是以字节为单位

字节序分为大端字节序(大端序)和小端字节序(小端序)

大端字节序:就是把地位放在高地址上

小端字节序:就是把低位(小)放在低地址(小)上 (小小小)

总的来说,小端序的应用更广泛。字节序是和CPU相关的属性,Intel的CPU主要都是小端序~

上述例子:0x11223344 内存数据若是11223344,则为大端序,44332211则为小端序。

程序判断大端序or小端序?

int isBidEnd() {
	int num = 0x11223344;
	int* p = #
	char* p2 = (char*)p;
	if (*p2 == 0x11) {
		return 1;
	}
	else {
		return 0;
	}
}
int main() {
	int ret = isBidEnd();
	if (ret == 1) {
		printf("是大端序\n");
	}
	else {
		printf("是小端序\n");
	}
	system("pause");
	return 0;
}

指针之间的强制类型转换,不会影响指针内部存储的地址值,只影响后序的解引用操作~

网络传输的字节序固定使用大端~

补码

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

原码:在正数的二进制基础上,把符号位设为1

反码:符号位不变,其他位取反~

补码:反码+1,即可得到补码

正数的原码、反码和补码都相同

举例:

int main() {
   char a = -1;
   signed char b = -1;//char 和signed char 没区别
   unsigned char c = -1;
   printf("a=%d\nb=%d\nc=%d\n", a, b, c);
   system("pause");
   return 0;
}

类型转换的规则

1.把长的数据转换成短的数据,高位直接"截断"

2.把短的数据转为成长的数据,高位要补符号位

浮点型在内存中的存储

小数在计算机中的计算要比整数复杂很多~

浮点数储存规则:

IEEE754规定:

对于32位的浮点数:

最高的一位是符号位s,接着的8位是指数E,剩下的23位为有效数字M

对于64位的浮点数:

最高的一位是符号位S,接着的11位是指数E,剩下的52位为有效数组M

一个浮点数在计算机里是运用"科学计数法"的方式来表示的~用2的多少次方来表示

2^E (2的E次方)

E越大,能表示的数据范围就越大

M越大,能表示的数据的精度就越高

因此优先考虑使用double

内存

一定要把内存理解透彻~~指针基础篇里有写内存,可以去看看~

总结

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

(0)

相关推荐

  • 关于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语言详细分析浮点数在内存中的储存

    目录 浮点数的储存格式 初步了解 深入探究 E不全为0或不全为1 E全为0 E全为1 浮点数的储存格式 初步了解 首先让我们通过一段代码来认识一下浮点型和整型的区别: int main() { int n = 9;//将整型9存储到n中 float* pFloat = (float*)&n; printf("n的值为:%d\n", n); printf("*pFloat的值为:%f\n", *pFloat); *pFloat = 9.0;//将浮点型9.0存

  • C/C++的浮点数在内存中的存储方式分析及实例

    C/C++的浮点数在内存中的存储方式分析 任何数据在内存中都是以二进制的形式存储的,例如一个short型数据1156,其二进制表示形式为00000100 10000100.则在Intel CPU架构的系统中,存放方式为  10000100(低地址单元) 00000100(高地址单元),因为Intel CPU的架构是小端模式.但是对于浮点数在内存是如何存储的?目前所有的C/C++编译器都是采用IEEE所制定的标准浮点格式,即二进制科学表示法. 在二进制科学表示法中,S=M*2^N 主要由三部分构成

  • C++浮点数在内存中的存储详解

    目录 前言: 浮点数的表示形式 浮点数存储模型 有效数字M 指数E 例题讲解 总结 前言: 我们在码代码的时候,经常遇到过以整数形式存入,浮点数形式输出:或者浮点数形式存入整数形式输出.输出的结果往往让人意想不到,那么,为什么会发生这样的变化,又是什么导致发生变化,接下来,就让我们从存储内部结构出发,带你深度解刨! 我们以一个例子来说明一切 #include<stdio.h> int main() { int n = 9; float *pFloat = (float *)&n; pr

  • 深入C/C++浮点数在内存中的存储方式详解

    任何数据在内存中都是以二进制的形式存储的,例如一个short型数据1156,其二进制表示形式为00000100 10000100.则在Intel CPU架构的系统中,存放方式为  10000100(低地址单元) 00000100(高地址单元),因为Intel CPU的架构是小端模式.但是对于浮点数在内存是如何存储的?目前所有的C/C++编译器都是采用IEEE所制定的标准浮点格式,即二进制科学表示法.在二进制科学表示法中,S=M*2^N 主要由三部分构成:符号位+阶码(N)+尾数(M).对于flo

  • 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++中整形与浮点型如何在内存中的存储详解

    目录 1 数据类型 1.1 类型的基本归类 2 整形在内存中的存储 2.1 二进制的三种形式 2.2 大小端字的介绍 3 浮点数在内存中的存储 3.1 浮点数存储规则 1 数据类型 前面我们已经知道了基本的内置类型: 类型的意义: 1. 使用这个类型开辟内存空间的大小(大小决定了使用范围). 2. 如何看待内存空间的视角. 1.1 类型的基本归类 整形家族: char unsigned char signed char short unsigned short [int] signed shor

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

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

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

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

随机推荐