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

 更新时间:2021年06月03日 14:29:54   作者:一朵花花  
之前对c语言数据存储一直不太明白,最近仔细研究了一番,所以下面这篇文章主要给大家介绍了关于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语言数据存储内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • C++实现图书管理系统课程设计(面向对象)

    C++实现图书管理系统课程设计(面向对象)

    这篇文章主要为大家详细介绍了C++实现图书管理系统课程设计,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-03-03
  • C++使用函数的一些高级操作指南

    C++使用函数的一些高级操作指南

    C++中函数调用的方法与C语言并无区别,依旧是在调用方函数中执行函数调用语句来实现函数调用,下面这篇文章主要给大家介绍了关于C++使用函数的一些高级操作,文中通过图文介绍的非常详细,需要的朋友可以参考下
    2022-12-12
  • C C++ LeetCode题解在二叉树中增加一行示例详解

    C C++ LeetCode题解在二叉树中增加一行示例详解

    这篇文章主要为大家介绍了C C++ LeetCode题解在二叉树中增加一行示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-10-10
  • C++ 类的赋值运算符''''=''''重载的方法实现

    C++ 类的赋值运算符''''=''''重载的方法实现

    这篇文章主要介绍了C++ 类的赋值运算符'='重载的方法实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-02-02
  • C语言超详细讲解数据结构中的线性表

    C语言超详细讲解数据结构中的线性表

    线性表,数据结构中最简单的一种存储结构,专门用于存储逻辑关系为"一对一"的数据。线性表是基于数据在实际物理空间中的存储状态,又可细分为顺序表(顺序存储结构)和链表
    2022-05-05
  • Qt使用QJson模块实现解析Json文件

    Qt使用QJson模块实现解析Json文件

    在项目开发过程中,经常会遇到读写Json文件的需求,掌握Json文件的操作是基础中的基础,下面我们就来看看如何使用QT内置的QJson模块解析Json文件吧
    2023-10-10
  • 利用C语言模拟实现qsort,strcpy,strcat,strcmp函数

    利用C语言模拟实现qsort,strcpy,strcat,strcmp函数

    这篇文章主要为大家详细介绍了如何通过C语言模拟实现qsort(采用冒泡的方式),strcpy,strcat,strcmp等函数,文中的示例代码讲解详细,感兴趣的可以了解一下
    2022-11-11
  • C++ Boost PointerContainer智能指针详解

    C++ Boost PointerContainer智能指针详解

    智能指针是一种像指针的C++对象,但它能够在对象不使用的时候自己销毁掉。虽然STL提供了auto_ptr,但是由于不能同容器一起使用(不支持拷贝和赋值操作),因此很少有人使用。它是Boost各组件中,应用最为广泛的一个
    2022-11-11
  • C语言入门之基础知识详解

    C语言入门之基础知识详解

    这篇文章主要介绍了C语言入门之基础知识详解,文中有非常详细的C语言使用教程及相关基础知识,对正在学习c语言的小伙伴们有非常好的帮助,需要的朋友可以参考下
    2021-04-04
  • opencv3/C++ PHash算法图像检索详解

    opencv3/C++ PHash算法图像检索详解

    今天小编就为大家分享一篇opencv3/C++ PHash算法图像检索详解,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-12-12

最新评论