温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

C语言动态数组详细介绍

发布时间:2021-09-13 17:03:31 来源:亿速云 阅读:132 作者:chen 栏目:开发技术

这篇文章主要介绍“C语言动态数组详细介绍”,在日常操作中,相信很多人在C语言动态数组详细介绍问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”C语言动态数组详细介绍”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

目录
  • 内存分配函数malloc calloc realloc free

  • 内存操作函数 memset memcpy memmove

  • 二维动态数组的建立和释放


内存分配函数malloc calloc realloc free

堆内存分配函数说明
void * malloc(int n)形参n为要求分配的字节数。需要注意的是,malloc函数分配得到的内存空间是未初始化的。必须使用memset函数来初始化。
calloc(10, sizeof(char));两个参数:单元数,单元的size。分配内存,并清理内存。初始内容全部为0;
realloc(p,10);调整内存的大小; 分配的内存空间并未初始化;使用新返回的地址,
free(void * p)释放指针p所指向的堆上的空间;

malloc() 不对分配的内存空间做初始化,内存上原有的值不会被清理。

realloc(),在原有内存基础之上,在堆中间增加连续的内存,如果原有内存没有连续空间可扩展,则新分配一个空间,将原有内存copy到新空间,然后释放原有内存。

p = malloc(10);	//直接申请4k的空间。内存页大小。  返回值是无类型指针void *,可以强制转换。
free(p);
char *p = calloc(10, sizeof(char));	 //两个参数:单元数,单元的size。		分配内存,并清理内存
char *p2 = realloc(p,10);		// 在原有内存基础之上,在堆中间增加连续的内存,如果原有内存没有连续空间可扩展,则新分配一个空间,将原有内存copy到新空间,然后释放原有内存。
char *p2 = realloc(NULL,20);	//此时,和malloc等价

realloc和malloc一样,只分配内存,不清理,需要手动初始化。

// 复杂数据内存放在堆里面

内存操作函数 memset memcpy memmove

memset(buf,0,sizeof(buf));//三个参数分别是:要设置的内存地址,要设置的值,值占的内存的字节数。	将一块内存初始化为0最长见的方法。
extern void *memset(void *buffer, int c, int count) 
memcpy(void *dest,void *src,unsigned int count);//将buf1的地址的内存内容全部拷贝到buf2,拷贝大小为第三个参数:字节一定确保内存区域没有内存区域重叠。
memmove(buf2, buf1, sizeof(buf1));//内存移动,并没有改变原始内存的值。

二维动态数组的建立和释放

在创建动态数组的过程中我们要遵循一个原则,那就是在创建的时候从外层往里层,逐层创建;
而释放的时候从里层往外层,逐层释放。

int main()
{
	int num1,num2;
	num1 = 4;
    num2 = 5;
	int **array = (int **)calloc(num1,sizeof(int *));//开辟空间,num1个一维int*型指针
	for(int i=0;i<num1;i++)
	{
		array[i] = (int *)calloc(num2,sizeof(int));		//给每个int *型指针分配内存
	}
	for(int i=0;i<num1;i++)
	{
		for(int j=0;j<num2;j++)
		{
			array[i][j] =i*num2+j+1;
			printf("%d\t",array[i][j]);
		}
		printf("\n");
	}
	for(int i=0;i<num1;i++)
	{
		free(array[i]);		// 释放第二维的内存
	}
	free(array);			// 释放第一维的内存
	return 0;
}

到此,关于“C语言动态数组详细介绍”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI