C动态分配

动态分布与静态发布:

静态分配

1、 在程序编译或运行过程中,按事先规定大小分配内存空间的分配方式。int a 10

2、 必须事先知道所需空间的大小。

3、 分配在栈区或全局变量区,一般以数组的形式。

4、 按计划分配。

动态分配

1、在程序运行过程中,根据需要大小自由分配所需空间。

2、按需分配。

3、分配在堆区,一般使用特定的函数进行分配。

动态内存分配函数

1.malloc函数

该函数仅针对于指针使用,使用前需要引用malloc.h函数

void*** malloc (unsignedintsize)**

  • 参数size:

  • size:要开辟的空间的大小

  • 返回值:

  • 成功:开辟好的空间的首地址

  • 失败:NULL

在内存的动态存储区(堆)中++分配一个长度为size的连续空间。其参数是一个无符号整数,返回值是一个系统所分配的连续内存空间的起始地址++。

若分配内存空间失败(如内存不足等原因)则返回NULL。所以,使用前一定要判断是否为NULL

objectivec 复制代码
#include <stdio.h>
#include <stdlib.h>
int main(){

    int num;
    scanf("%d",&num);
    int *ptr=(int *)malloc(num*sizeof(int));
    if(ptr==NULL){
        printf("内存分配失败!\n");
        exit(1);
    }
    else {
        printf("success!");
    }
    for(int i=0;i<num;i++){
        scanf("%d",&ptr[i]);
    }
    for(int i=0;i<num;i++){
        printf("%d ",ptr[i]);
    }
    putchar('\n');
    free(ptr);
    return 0;
}

2.free函数

#include <stdlib.h>

void free(void *p)

功能:释放堆区的动态内存空间

参数:

ptr:开辟后使用完毕的堆区的空间的首地址

返回值:

注意:

  • free函数只能释放堆区的空间,其他区域的空间无法使用free
  • free释放空间必须释放malloc或者calloc或者realloc的返回值对应的空间,不能说只释放一部分
  • free(p); 注意当free后,因为没有给p赋值,所以p还是指向原先动态申请的内存。但是内存已经不能再用了,p变成野指针了,所以一般为了放置野指针,会free完毕之后对p赋 为NULL
  • 一块动态申请的内存只能free一次,不能多次free。

//使用free函数释放空间

ferr(p);

//防止野指针

p=NULL;

链表的基本概念

链表,是为了实现动态保存 一串数据 。注意这里的动态是指不需要预先分配 内存空间,而是在需要时动态申请内存。整个数据串保存所需的空间可以根据需要扩大或缩小。而设计的一种数据结构。如:

链表的节点结构

**1.数据域:**用来储存数据

2.指针域:储存下一个节点元素的地址

如果有后继元素,则指针link会指向下一个元素,若无,这指针指向NULL

objectivec 复制代码
struct Stu{
   char name[20];
   int age;
   struct Stu *link;
}
相关推荐
爱学习的程序媛2 天前
C 语言全景指南:从底层原理到工业级实战
c++·c#·c
dozenyaoyida3 天前
RISC-V嵌入式开发:彻底解决“undefined reference to isatty“错误全攻略
经验分享·c·cmake·嵌入式开发·isatty·没有定义问题
Shadow(⊙o⊙)4 天前
模拟实现:glibc_1.0-文件操作函数fopen fclose fwrite fflush实现。
开发语言·c++·学习·c
liulilittle5 天前
TCP UCP:基于卡尔曼滤波的BBR增强型拥塞控制算法
linux·网络·c++·tcp/ip·算法·c·通讯
weixin_421725267 天前
C语言、C++与C#深度研究报告:从底层控制到现代企业级开发的演进
c语言·c++·c·内存管理·编译模型
不吃土豆的马铃薯9 天前
Spdlog 入门:日志记录器与日志槽基础详解
服务器·开发语言·c++·c·日志·spdlog
金创想9 天前
积木移动题目分析及解题思路——木块问题(1)
c++·算法·字符串·c·刷题·信息学奥赛·积木
不吃土豆的马铃薯12 天前
5.SGI STL 二级空间配置器 _S_chunk_alloc核心函数解析
开发语言·c++·vscode·c·内存池
一只小灿灿13 天前
深度详解计算机补码原理
c·补码
liulilittle13 天前
TCP UCP v1.0 拥塞控制算法(Linux Kernel CC-A)
linux·网络·网络协议·tcp/ip·c·通信·拥塞控制