快上网专注成都网站设计 成都网站制作 成都网站建设
成都网站建设公司服务热线:028-86922220

网站建设知识

十年网站开发经验 + 多家企业客户 + 靠谱的建站团队

量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决

c语言动态内存分配知识点及实例

c语言怎么实现动态内存分配

站在用户的角度思考问题,与客户深入沟通,找到太仆寺网站设计与太仆寺网站推广的解决方案,凭借多年的经验,让设计与互联网技术结合,创造个性化、用户体验好的作品,建站类型包括:网站设计、网站建设、企业官网、英文网站、手机端网站、网站推广、域名注册、网络空间、企业邮箱。业务覆盖太仆寺地区。

我们经常会预先给程序开辟好内存空间,然后进行操作。

int arr[5] ;

对这个数组我们在定义的时候必须给提前开辟好空间,并且在程序执行的过程中,这个开辟的内存空间是一直存在的,除非等到这个函数执行完毕,才会将空间释放。有个问题就是这个数组在程序中无法被修改。

这些问题给我们造成了一些使用上的不方便,所以,C中提供了malloc()函数。

关于malloc()函数,这个函数它接受一个参数:就是所需的内存的字节数。然后malloc()找到可用内存中那一个大小适合的块。在这个过程中,malloc()可以来返回那块内存第一个字节的地址。所以,也就意味了我们可以使用指针来操作。malloc()可以用来返回数组指针、结构指针等等,所以我们需要把返回值的类型指派为适当的类型。当malloc()找不到所需的空间时,它将返回空指针。

例:

double *p;

p=(double*)malloc(30*sizeof(double));

在这个程序中,首先开辟了30个double类型的空间,然后把p指向这个空间的位置。在这里的指针是指向第一个double值。并不是我们全部开辟的30个double的空间。这就和数组一样,指向数组的指针式指向数组首元素的地址,并不是整个数组的元素。所以,在这里我们的操作也和数组是一样的,

p[0]就是第一个元素,p[1]就是第二个元素。

至此,我们就可以掌握到一种声明动态数组的方法。

int arr[n];

p=(int *)malloc(n*sizeof(int));

//我们在这里使用的时候要元素个数乘类型字节长度,这样就达到了动态开辟内存空间。

当我们使用malloc()开辟完内存空间以后,我们所要考虑的就是释放内存空间,在这里,C给我们提供了free()函数。free()的参数就是malloc()函数所返回的地址,释放先前malloc()函数所开辟的空间。

例:

对于上面我们所开辟的空间进行释放,那么我们就可以这样

free(p);

程序还调用了exit()函数,这个函数是在内存分配失败时结束程序。

程序例子:

#define _CRT_SECURE_NO_WARNINGS 1
#include
#include//malloc()函数被包含在malloc.h里面
#include
int main(void)
{
  char*a = NULL;//声明一个指向a的char*类型的指针
  a = (char*)malloc(100 * sizeof(char));//使用malloc分配内存的首地址,然后赋值给a
  if (!a)//如果malloc失败,可以得到一些log
  {
    perror("malloc");
    return-1;
  }
  sprintf(a, "%s", "HelloWorld\n");//"HelloWorld\n"写入a指向的地址
  printf("%s\n", a);//输出用户输入的数据
  free(a);//释放掉使用的内存地址
  system("pause");
  return 0;//例2有无内存泄露?
}

这个程序主要用来检测malloc返回值条件有误。

在这里我们需要注意,在C中,类型指派(char *)是可选的,但是在C++中这个是必须有的,所以使用类型指派将使把C程序移植到C++更容易。

使用动态数组,主要是为了获得程序的灵活性。我们可以需要多少个元素就让数组开辟多少个。不需要浪费空间。

知识点补充:

常见的动态内存错误

常见的错误有:对NULL指针进行解引用操作、对分配的内存进行操作时越过边界、释放并非内存分配的内存、试图释放一块动态分配的内存的一部分以及一块动态内存释放之后被继续使用。

到此这篇关于c语言动态内存分配知识点及实例的文章就介绍到这了,更多相关c语言怎么实现动态内存分配内容请搜索创新互联以前的文章或继续浏览下面的相关文章希望大家以后多多支持创新互联!


当前文章:c语言动态内存分配知识点及实例
分享链接:http://6mz.cn/article/jeepdj.html

其他资讯