深度解析C语言中数据的存储

 更新时间:2022年05月24日 14:24:02   作者:爱弹吉他的小奔同学  
本文详细介绍了C语言中数据的存储,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

前言

在VS编译器里有release和debug两种形式,debug包含调试信息,release不包含调试信息,并会对程序进行优化

int main()
{
	int i = 0;
	int arr[10] = { 1,2,3,4,5,6,7,8,9,10 };

	for (i = 0; i <= 12; i++)
	{
		arr[i] = 0;
		printf("hehe\n");
	}
	
	return 0;
}

运行这个程序,结果是死循环打印hehe,为什么呢?

我们看内存

在循环到第13次时,把存储变量i的地方改为0,i<=12仍成立,形成死循环

这是debug下出现的情况,但是如果是release的配置下,就不会出现上面死循环的情况,原因在下面这个图里

在debug配置下,储存i变量的地址比储存arr数组的地址高,可能会越界到i的地址导致死循环

在release配置下,储存i变量的地址比储存arr数组的地址低,不会出现越界到i导致死循环

(如果你非写一个死循环那就真的死循环了,release优化没有那么万能)

数据类型介绍

类型 大小(单位为字节)
char (字符数据类型)1
short (短整型)2
int (整形)4
long (长整型)4或8
long long (更长的整形)8
float (单精度浮点数)4
double (双精度浮点数)8

long long是在C99增加的

long的大小和环境有关,32位平台上是4个字节,64位平台上是8个字节

这些都是C中内置的数据类型

类型的意义:

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

看待内存空间的视角

1就是不同类型可以开辟不同大小的内存空间

对于2,看下图理解

类型的基本归类

整型家族

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

在C99后又加了long long

long long
   unsigned long long [int]
   signed long long [int]

这些都是整型家族里的数据类型,都分有符号和无符号类型

为什么说字符数据类型也是整型呢?

因为字符的本质其实是ASCII 码值,是整型,所以划分到整型家族

一般我们都默认不加unsigned或signed的默认为是有符号的,但是char就有点特殊

char里有三个

  • char
  • signed char
  • unsigned char

signed char就是有符号的char,unsigned char就是无符号的char,但是什么都不加的char是有符号的还是无符号的标准是未定义的,取决于编译器的实现,跟编译器有关

其他都不加的int,short,long等都是默认为有符号的

那么为什么会有unsigned和signed之分呢?

因为生活中本来就有很多数据是没有负数的,比如身高,体重,长度

也有很多数据是有正负之分的,比如温度,放出或吸收热量

所以我们需要用unsigned和signed来区分是否有正负之分

举例子

int a = 10;

a是整型,有符号的整型,一个整型4个字节,即32个bit

0000 0000 0000 0000 0000 0000 0000 1010 (原码)

int a = -10;

1000 0000 0000 0000 0000 0000 0000 1010(原码)

符号位上,0表示正数,1表示负数,而且符号位不算有效位,只表示正负

有符号的int可以存 (-231)~(231-1)大小的数字

unsigned int a = -10;

1111 1111 1111 1111 1111 1111 0110(-10的补码)

无符号的int可以存0~232大小的数

因此,对于有正负的数,我们就用有符号的signed

对于没有正负之分的数,我们就用无符号的unsigned

浮点数家族

(只要表示小数就可以使用浮点型)

 float
 double

float精度低,存储的数值范围较小

double精度高,存储的数值范围较大

构造类型

数组类型

例如:

                      类型
int arr1[5];    ——>  int [5]
int arr2[8];    ——>  int [8]
char arr3[5]    ——>  char [5]

结构体类型

struct

枚举类型

enum

联合类型

union

指针类型

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

空类型

void 表示空类型(无类型)

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

举一个例子

void test(void);
//第一个void  表示函数不会返回值
//第二个void  表示函数不需要传任何参数

void*
//void用于指针类型,以后会详细讲解

以上就是深度解析C语言中数据的存储的详细内容,更多关于C语言数据存储的资料请关注脚本之家其它相关文章!

相关文章

  • C++的cout.tellp()和cout.seekp()语法介绍

    C++的cout.tellp()和cout.seekp()语法介绍

    无论是使用 cout 输出普通数据,用 cout.put() 输出指定字符,还是用 cout.write() 输出指定字符串,数据都会先放到输出流缓冲区,待缓冲区刷新,数据才会输出到指定位置,本文给大家介绍一下C++的cout.tellp()和cout.seekp()语法,需要的朋友可以参考下
    2023-09-09
  • C++ OpenGL实现三角形的绘制

    C++ OpenGL实现三角形的绘制

    这篇文章主要主要为大家详细介绍了如何利用C++和OpenGL实现三角形的绘制,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起动手尝试一下
    2022-06-06
  • 深入了解C语言栈的创建

    深入了解C语言栈的创建

    栈只允许在一端进行插入或删除操作的线性表。首先栈是一种线性表,但是限定这种线性表只能在某一端进行插入和删除操作,这篇文章主要介绍了C语言对栈的实现基本操作
    2021-07-07
  • c++实现reactor高并发服务器的详细教程

    c++实现reactor高并发服务器的详细教程

    这篇文章主要介绍了c++从零实现reactor高并发服务器,包括环境准备和基础知识介绍,本文给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧
    2024-03-03
  • C语言的常量和字符串

    C语言的常量和字符串

    这篇文章主要为大家介绍了C语言常量和字符串,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2021-12-12
  • C语言各种操作符透彻理解下篇

    C语言各种操作符透彻理解下篇

    C 语言提供了丰富的操作符,除了上篇中的算术操作符,移位操作符,位操作符,赋值操作符外,还有单目操作符、关系操作符、逻辑操作符、条件操作符等等,让我们通读本篇来详细了解吧
    2022-02-02
  • C++中的throw关键字详解

    C++中的throw关键字详解

    throw关键字是在C语言中用来抛出异常的关键字,它通常与try和catch一起使用,用于在程序中发生错误时进行异常处理,当遇到无法处理的错误情况时,我们可以使用throw关键字主动抛出异常,所以本文给大家详细的介绍一下C++中的throw关键字,需要的朋友可以参考下
    2023-09-09
  • VSCode搭建STM32开发环境的实现步骤

    VSCode搭建STM32开发环境的实现步骤

    因为VSCode免费且好用,可以安装各种插件,本文主要介绍了VSCode搭建STM32开发环境的实现步骤,具有一定的参考价值,感兴趣的可以了解一下
    2023-12-12
  • OpenGL实现不规则区域填充算法

    OpenGL实现不规则区域填充算法

    这篇文章主要为大家详细介绍了OpenGL实现不规则区域填充算法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-02-02
  • OpenGL绘制三次Bezier曲线

    OpenGL绘制三次Bezier曲线

    这篇文章主要为大家详细介绍了OpenGL绘制三次Bezier曲线,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-04-04

最新评论