服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - C/C++ - 深度解析C语言中数据的存储

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

2022-12-08 12:15爱弹吉他的小奔同学 C/C++

本文详细介绍了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
");
	}
	
	return 0;
}

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

我们看内存

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

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

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

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

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

在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,看下图理解

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

类型的基本归类

整型家族

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 (原码)

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

int a = -10;

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

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

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

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

unsigned int a = -10;

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

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

无符号的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语言数据存储的资料请关注服务器之家其它相关文章!

原文地址:https://blog.csdn.net/iqrmshrt/article/details/124936663

延伸 · 阅读

精彩推荐
  • C/C++浮点数在计算机中存储方式是怎样的

    浮点数在计算机中存储方式是怎样的

    这篇文章介绍了浮点数在计算机中是如何存储的,讲解的比较详细,有需要的朋友可以参考一下。...

    Robin9952021-04-07
  • C/C++C语言实现三子棋(井字棋)算法

    C语言实现三子棋(井字棋)算法

    这篇文章主要为大家详细介绍了C语言实现三子棋(井字棋)算法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    爱编辑6822021-12-08
  • C/C++C++如何实现简单的计时器详解

    C++如何实现简单的计时器详解

    因为最近闲着无聊就想着要不用C++写点什么东西,仔细想了想其实自己的C++学的也不怎么好,写个简单的计时器吧!所以下面这篇文章主要介绍了利用C++如...

    小博computing8762021-04-28
  • C/C++详解C++中的双冒号 ::

    详解C++中的双冒号 ::

    这篇文章主要介绍了C++中的双冒号 ::,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧...

    有梦想的伟仔10382021-09-27
  • C/C++详解c++中的 static 关键字及作用

    详解c++中的 static 关键字及作用

    这篇文章主要介绍了c++中的 static 关键字,在我们日常使用过程中,static通常有两个作用,具体内容在文中给大家详细介绍,需要的朋友可以参考下...

    PRO_Z5692021-08-17
  • C/C++VScode编译C++ 头文件显示not found的问题

    VScode编译C++ 头文件显示not found的问题

    这篇文章主要介绍了VScode编译C++ 头文件显示not found的问题,本文给大家分享问题解决方法,通过截图的形式给大家介绍的非常详细,需要的朋友可以参考下...

    SuperAFeiDa8652021-08-27
  • C/C++OpenCV图像处理基本操作详解

    OpenCV图像处理基本操作详解

    这篇文章主要为大家详细介绍了OpenCV图像处理基本操作,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    凌花钱6712021-10-26
  • C/C++c/c++输出重定向的方法

    c/c++输出重定向的方法

    c/c++输出重定向的方法,需要的朋友可以参考一下...

    C语言教程网5132020-11-18