• 第八章:动态内存申请


    malloc

    void *malloc(unsigned int size)
    在内存的动态存储区(堆)中分配一块长度为size字节的连续区域,用来存放说明符指定的类型。分配的内存空间内容不确定。
    一般使用memset初始化

    返回值:
    分配空间的起始地址:表示分配成功
    NULL:表示分配失败

    main() {
    	int* p;
    	p = (int*)malloc(100*sizeof(int));
    	if (p == NULL) {
    		return 0;
    	}
    	for (int i = 0; i < 100; i++) {
    		p[i] = i;
    	}
    	for (int i = 0; i < 100; i++) {
    		printf("%d\n", p[i]);
    	}
    	free(p);
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14

    calloc

    void *calloc(size_t nmemb, size_t size);
    size_t是无符号整型。
    在内存的堆中,申请nmemeb块,每块的大小为size个字节的连续区域。分配的内存中的内容为0
    返回值:
    分配空间的起始地址:表示分配成功
    NULL:表示分配失败

    realloc

    重新申请内存。
    使用malloc和calloc函数,单次申请的内存是连续的,再次申请的内存不一定和之前的连续。
    为了内存连续,先用malloc或者calloc申请内存,然后使用realloc申请内存,就和之前的连续了。

    void * realloc(void *s, unsigned int newsize);
    在原先s指向的内存基础上重新申请内存,新的内存为newsize个字节。如果原先内存后面又足够大的空间,就追加。否则realloc函数会在堆区找一个newsize个字节大小的内存申请,将原先内存中的内容拷贝过来,释放之前的内存。

    如果newsize比原来的内存小,则会释放原来内存后面的存储空间,只保留前面newsize个字节的内存。

    free(内存泄漏)

    申请的内存,首地址丢了,再也没法使用了,也没法释放。

    //p指向了其他地方,申请的内存没有释放,也没法使用。
    int main()
    {
      char *p;
      p = (char*)malloc(100);
      p = "hello";
      return 0;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
     char *p;
      p = (char*)malloc(100);
      free(p);//释放内存
    
    • 1
    • 2
    • 3

    释放内存,释放的内存必须是malloc calloc relloc动态申请的内存。
    申请内存后,需要使用free进行释放。

  • 相关阅读:
    支持中文!秒建 wiki 知识库的开源项目,构建私人知识网络
    Nacos 注册中心和配置管理的数据一致性
    校招能成功上岸阿里、百度测试岗都是什么样的人~
    DIY USB3.0 SM2246XT+双贴闪迪15131颗粒256G固态U盘
    求解组合数
    流媒体分析之srt协议ffmpeg 实现
    100道基于Android毕业设计的选题题目,持续更新
    java异步
    资管巨头贝莱德增持矿企股份,机构资金正在慢慢进入比特币经济……
    太空 5G 在启动板上
  • 原文地址:https://blog.csdn.net/LookOutThe/article/details/133612992