首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    数组大小分配(动态内存分配)

    在很多情况下,我们无法确定要使用多大的数组。一般申请大于估计数目的固定大小,这样程序在运行时就申请了固定的大小,你觉得数组定义足够大,但是如果某种原因,数组的个数增大或减小,你又必须重新修改程序,扩大数组的存储范围。这种分配固定大小内存分配的方法称为静态内存分配。但是这种分配方法存在比较严重的缺陷,特别是处理某些问题时,在大多数情况下会浪费大量的内存空间;在少数情况下,当申请的数组不够大时,可能引起下标越界错误,甚至导致严重的后果。 为了解决这个问题,提出了动态内存分配。所谓动态内存分配是指在程序执行的过程中动态地分配或者回收存储空间的内存分配方法。动态分配不像数组等静态内存分配方法需要预先申请内存空间,而是由系统根据程序的需要即时分配,且分配的大小就是程序要求的大小。从以上动、静态内存分配比较可以知道动态内存分配相对于静态内存分配的特点:

    02

    顺序表的定义_顺序表的逻辑顺序和物理顺序

    来看一个生活中的例子:周末和朋友一起吃火锅,人非常多,我们需要在等候区等候,这个等候区就与顺序表有非常多的相似之处,借助它去理解顺序表的特点。首先,在等候区有非常多的椅子,这些椅子往往是排成一排连续排放的,中间不会空出很大的空间造成浪费。这就与在顺序表中选取存储单元的方法是一样的,我们会选取一段地址连续的存储单元去存放顺序表。接着工作人员会安排我们在椅子上连续的坐下等候。在存储单元当中去进行数据的存放是一样的,也是依次地存放线性表当中的数据元素,中间也不会空出许多存储单元造成空间的浪费。最后结伴而行的朋友也会坐在相邻的椅子上,这与顺序表的存放是相同的。在逻辑上相邻的两个元素在物理位置上也要保证它相邻,也会把它存放在相邻的存储单元上。在这个例子当中,其实椅子就代表着存储单元,而每一个等候的人就是要存放的数据元素。来总结一下顺序表的特点:

    01

    free函数的用法和注意事项

    1. 只能释放由malloc、calloc、realloc函数分配的内存空间,不能释放其他类型的内存。 2. 不能释放已经被释放过的内存。 3. 释放内存后,不要再使用该内存空间,否则会导致未定义的行为。 4. 传递给free函数的指针必须是动态分配的指针,不能是静态分配的指针或栈上的指针。 5. free函数并不会改变指针的值即不会将指针设置为`NULL,只是释放指针指向的内存空 6. 不建议频繁地调用free函数,可以尽量将多个内存释放操作合并到一起,以避免频繁的内存分配和释放操作带来的性能损失。对同一个内存块多次调用`free()`函数是非法的,可能导致程序崩溃或其他未定义行为。 - 释放已经释放过的内存块也是非法的,同样可能导致程序崩溃或其他未定义行为。 - 在释放内存块之前,应该确保不再使用该内存块的指针。

    01

    C语言 动态内存分配

    动态内存分配涉及到堆栈的概念:堆栈是两种数据结构。堆栈都是数据项按序排列的数据结构,只能在一端(称为栈顶(top))对数据项进行插入和删除。 栈(操作系统):由操作系统自动分配释放 ,存放函数的参数值,局部变量的值等。其操作方式类似于数据结构中的栈。 堆(操作系统): 一般由程序员分配释放, 若程序员不释放,程序结束时可能由OS回收,分配方式倒是类似于链表。 在C语言中,全局变量分配在内存中的静态存储区,非静态的局部变量(包括形参)是分配在内存的动态存储区,该存储区被称为栈。除此之外,C语言还允许建立内存动态分配区域,以存放一些临时用的数据,这些数据不必在程序的声明部分定义,也不必等到函数结束时才释放,而是需要时随时开辟,不需要是随时释放。这些诗句临时存在一个特别的自由存储区,称为堆区。 系统提供了四个库函数来实现内存的动态分配: (1)malloc(size) 在内存的动态存储区中分配一个长度为size的连续空间。 (2)calloc(n,size) 在内存的动态存储区中分配n个长度为size的连续空间。 (3)free§ 释放指针变量p做指向的动态空间。 (4)realloc(p,size) 将指针变量p指向的动态空间大小改变为size。 举个栗子:

    02
    领券