当前位置: 首页 > news >正文

C语言 DAY10 内存分配

1.引入

        int nums[10] = {0}; //对
        int len = 10;
        int nums[len] = {0}; //错
        是因为系统的内存分配原则导致的

2.概述

        在系统运行时,系统为了更好的管理进程中的内存,所以将内存进行了分配,其分配的机制就称为内存分配

1.静态分配原则

        1.特点

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

                2、必须事先知道所需空间的大小。
                3、分配在栈区或全局变量区,一般以数组的形式。
                
                4、按计划分配

  2.动态分配原则

        1.特点

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

                2、按需分配。
                3、分配在堆区,一般使用特定的函数进行分配。
        案例
                班级有15个学员,定义数组记录学员成绩
        double score[15] = {0};
        记录学员成绩
        1,输入学员数量
        2,在堆区申请
        3,扩展
        4,释放
注意
c 语言中提供了一系列动态分配内存的函数
这些函数大部分都在 stdlib.h 头文件中声明
free 释放
malloc 申请空间 , 默认值随机
calloc 申请空间 , 默认值为 0
realloc 扩展空间
string.h 中提供的函数
memset malloc 中的随机数设为 0

3.动态内存分配    

memset函数

作用:重置

语法:

#include <string.h>

void *memset = (void *s,int c,size_t  n);

s:原指针

c:重置后的数据

n:重置的数量

s开始,n个字节的数据,设置为c

示例:     

#include<stdio.h>
#include<string.h>
int main(int argc, char const *argv[])
{
        char strs[10] = {0};
        memset(strs,'a',10*1);
        for (int i = 0; i < 10; i++)
        {
        printf("%c ",strs[i]);
        }
        printf("\n");
        int nums[10] = {1,2,3,4,5,6,7,8,9,10};
        memset(nums,0,10 * 4);
        for (int i = 0; i < 10; i++)
        {
        printf("%d ",nums[i]);
        }
        printf("\n");
        return 0;
}

free函数

作用:释放空间

语法:

        #include<stdlib.h>

        void free(指针变量名);

malloc函数

作用:在堆中开辟一段内存空间

语法:

        #include<stdlib.h>

        void *malloc (size_t size);

参数:
        size:开辟空间大小,单位字节,size_t可以理解为无符号int
返回值:
        开辟的空间的地址
        开辟失败返回NULL
注意:
        1,在使用malloc需要判断是否开辟成功
        2,如果多次 malloc 申请的内存,第 1 次和第 2 次申请的内存不一定是连续的
        3,malloc的返回值在使用中记得强制类型转换
        4,malloc从堆区申请空间后 空间的内容中的值是随机的(与局部变量一样大概率为0),可以使用
memset函数对空间中的数据进行置
示例:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int main(int argc, char const *argv[])
{
//1, 申请空间
// 申请一个可以存储 10 int 数据的空间
        int *p = (int *)malloc(10 * sizeof(int));
//2, 判断是否开辟失败
        if (p == NULL)
        {
        printf("开辟失败 \n");
        return 0;
        }
// 0
        memset(p,0,10 *sizeof(int));
//3, 使用空间
        // for (int i = 0; i < 10; i++)
        // {
        // scanf("%d",&p[i]);
        // }
        for (int i = 0; i < 10; i++)
        {
        printf("%d ",p[i]);
        }
        printf("\n");
        //4,释放空间
        free(p);
        return 0;
}

calloc函数

作用:在堆中开辟一段内存空间

语法:

#include <stdlib.h>

void *calloc(size_t nmemb, size_t size);

参数:
        nmemb:申请的块数
        size:每块的大小
返回值:
        开辟的空间的地址
        开辟失败返回NULL
        int *p = malloc(10 * sizeof(int));
        int *p = calloc(10,sizeof(int));

示例:   

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int main(int argc, char const *argv[])
{
//1, 申请空间
// 申请一个可以存储 10 int 数据的空间
        // int *p = (int *)malloc(10 * sizeof(int));
        int *p = (int *) calloc(10,sizeof(int));
//2, 判断是否开辟失败
        if (p == NULL)
        {
        printf("开辟失败 \n");
        return 0;
        }
// 0
        //memset(p,0,10 *sizeof(int));
//3, 使用空间
        for (int i = 0; i < 10; i++)
        {
        scanf("%d",&p[i]);
        }
        for (int i = 0; i < 10; i++)
        {
        printf("%d ",p[i]);
        }
        printf("\n");
//4, 释放空间
        free(p);
        return 0;
}

realloc函数 

作用:扩展空间

语法:

        void *realloc(void *ptr, size_t size);   

参数 :
        ptr:原指针
        size:从新开辟的大小 , 原大小 + 新开的大小
返回值 :
        开辟成功返回新地址
        开辟失败返回NULL
注意 :
        新地址不一定等于原地址, 但是大概率相同
示例:
#include <stdio.h>
#include <stdlib.h>
int main(int argc, char const *argv[])
{
    int *p = (int *)calloc(3,sizeof(int));
    int *p2 = (int *)calloc(3,sizeof(int));
    //...
    p = realloc(p,20);
    for(int i = 0; i < 5; i++)
    {
        scanf("%d",&p[i]);
    }
    for(int i = 0; i < 5; i++)
    {
        printf("%d,",p[i]);
    }
    printf("\n");
    free(p);
    return 0;
}

 

4.内存泄露

概念:      

        申请的内存,首地址丢了,找不了,再也没法使用了,也没法释放了,这块内存就被泄
露了。
情况1: 记录申请的内存的指针变量指向别的地方
        
int *p = (int *)malloc(40);
int nums[10] = {};
p = nums;
情况2: 在函数中申请空间 , 使用完毕没有释放
void test()
{
int *p = (int *)malloc(40);
}
test();
防止多次释放:
        示例:
        
        int *p = (int *)malloc(40);
        free(p);
        free(p);
        //注意多次释放会报错
口诀 : 释放前判断 , 释放后置 NULL
        
int *p = (int *)malloc(40);
if(p != NULL)
{
free(p);
p = NULL;
}
if(p != NULL)
{
free(p);
p = NULL;
}

相关文章:

C语言 DAY10 内存分配

1.引入 int nums[10] {0}; //对 int len 10; int nums[len] {0}; //错 是因为系统的内存分配原则导致的 2.概述 在系统运行时&#xff0c;系统为了更好的管理进程中的内存&#xff0c;所以将内存进行了分配,其分配的机制就称为内存分配 1.静态分配原则 1.特点 1、在程序…...

SpringCloud Gateway 网关的请求体body的读取和修改

SpringCloud Gateway 网关的请求体body的读取和修改 getway需要多次对body 进行操作&#xff0c;需要对body 进行缓存 缓存body 动态多次获取 新建顶层filter&#xff0c;对body 进行缓存 import lombok.extern.slf4j.Slf4j; import org.springframework.cloud.gateway.filt…...

气膜场馆的降噪方法

在现代社会&#xff0c;噪音已经成为我们生活中难以避免的问题&#xff0c;而气膜场馆也不例外。传统的气膜场馆常常因其特殊结构而面临噪音扩散和回声问题&#xff0c;影响了人们的体验和活动效果。然而&#xff0c;随着科技的进步&#xff0c;多功能声学综合馆应运而生&#…...

探索主题建模:使用LDA分析文本主题

在数据分析和文本挖掘领域&#xff0c;主题建模是一种强大的工具&#xff0c;用于自动发现文本数据中的隐藏主题。Latent Dirichlet Allocation&#xff08;LDA&#xff09;是主题建模的一种常用技术。本文将介绍如何使用Python和Gensim库执行LDA主题建模&#xff0c;并探讨主题…...

服务器黑洞,如何秒解

想必这样的短信大家都应该见过吧&#xff0c;这其实是阿里云服务器被攻击后触发的黑洞机制的短信通知。还有很多朋友不知道&#xff0c;为什么要这么做。原因其实很简单啊&#xff0c;当同一个机房的ip段&#xff0c;如果说有一台服务器遭受低道攻击&#xff0c;那么很可能会造…...

【生物信息学】单细胞RNA测序数据分析:计算亲和力矩阵(基于距离、皮尔逊相关系数)及绘制热图(Heatmap)

文章目录 一、实验介绍二、实验环境1. 配置虚拟环境2. 库版本介绍 三、实验内容0. 导入必要的库1. 读取数据集2. 质量控制&#xff08;可选&#xff09;3. 基于距离的亲和力矩阵4. 绘制基因表达的Heatmap5. 基于皮尔逊相关系数的亲和力矩阵6. 代码整合 一、实验介绍 计算亲和力…...

学习笔记三十一:k8s安全管理:认证、授权、准入控制概述SA介绍

K8S安全实战篇之RBAC认证授权-v1 k8s安全管理&#xff1a;认证、授权、准入控制概述认证k8s客户端访问apiserver的几种认证方式客户端认证&#xff1a;BearertokenServiceaccountkubeconfig文件 授权Kubernetes的授权是基于插件形成的&#xff0c;其常用的授权插件有以下几种&a…...

【开发新的】apache common BeanUtils忽略null值

前言: BeanUtils默认的populate方法不会忽略空值和null值&#xff0c;在特定场景&#xff0c;我们需要原始的值避免被覆盖&#xff0c;所以这里提供一种自定义实现方式。 package com.hmwl.service.program;import lombok.extern.slf4j.Slf4j; import org.apache.commons.beanu…...

coalesce函数(SQL )

用途&#xff1a; 将控制替换成其他值&#xff1b;返回第一个非空值 表达式 COALESCE是一个函数&#xff0c; (expression_1, expression_2, …,expression_n)依次参考各参数表达式&#xff0c;遇到非null值即停止并返回该值。如果所有的表达式都是空值&#xff0c;最终将返…...

一键报警可视对讲管理机10寸触摸屏管理机

一键报警可视对讲管理机10寸触摸屏管理机 一、管理机技术指标&#xff1a; 1、10寸LCD触摸屏&#xff0c;分辨率1024*600&#xff1b; 2、摄像头1200万像素 3、1000M/100M自适应网口&#xff1b; 4、按键设置&#xff1a;报警/呼叫按键&#xff0c;通话/挂机按键&#xff0…...

java左右括号

java左右括号 数据结构-栈栈的特点&#xff1a;先进后出代码实现 最近看到有小伙伴去面试&#xff0c;被人问起一道算法题&#xff0c;题目内容大概是&#xff1a;给定一个字符串&#xff0c;如&#xff1a;“[[]]{}”&#xff0c;判断字符串是否为有效的括号。考查的是数据结构…...

接口自动化测试 —— 工具、请求与响应

一、工具&#xff1a; 1.工具介绍 postman &#xff1a;很主流的API测试工具&#xff0c;也是工作里面使用最广泛的研发工具。 JMeter&#xff1a; ApiPost&#xff1a; 2.安装postman&#xff1a; 安装好直接打开&#xff0c;不用注册。 二、通信模式&#xff1a; 1、…...

【LeetCode:2103. 环和杆 | 模拟】

&#x1f680; 算法题 &#x1f680; &#x1f332; 算法刷题专栏 | 面试必备算法 | 面试高频算法 &#x1f340; &#x1f332; 越难的东西,越要努力坚持&#xff0c;因为它具有很高的价值&#xff0c;算法就是这样✨ &#x1f332; 作者简介&#xff1a;硕风和炜&#xff0c;…...

微信小程序-授权登录(手机号码)

1、WXBizDataCrypt.js-下载地址 2、UNIAPP代码 <template> <view class"work-container"> <view class"login"> <view class"content"> <button class"button_wx&q…...

视觉问答(VQA)12篇顶会精选论文合集,附常用数据集下载

今天来聊聊计算机视觉和自然语言处理交叉的一个热门研究方向&#xff1a;视觉问答&#xff08;VQA&#xff09;。 视觉问答的任务是&#xff1a;给出一张图片和一个关于这张图片的自然语言问题&#xff0c;计算机需要根据图片的内容自动回答这个问题。这样的任务考验了计算机在…...

详解--编码(ASCII\Unicode,UTF-8\UTF-16\UTF-32)

本文主要搞清楚编码是怎么回事。 参考链接 字符集编码方式ASCII&#xff08;American Standard Code for Information Interchange&#xff09;ASCIIGB2312GB2312UnicodeUTF-8 / UTF-16 / UTF-32 1.编码基本概念 1.1 字符 字符&#xff08;Character&#xff09; 在计算机和…...

Linux安装配置awscli命令行接口工具及其从aws上传下载数据

官网技术文档有全面介绍&#xff1a;安装或更新 AWS CLI 的最新版本 - AWS Command Line Interface在系统上安装 AWS CLI。https://docs.aws.amazon.com/zh_cn/cli/latest/userguide/getting-started-install.html#getting-started-install-instructionsawscli常用命令参考&…...

中国联通携手华为助力长城精工启动商用5G-A柔性产线

[中国&#xff0c;河北&#xff0c;2023年11月3日] 近日&#xff0c;中国联通携手华为助力精诚工科汽车系统有限公司保定自动化技术分公司&#xff08;简称长城精工自动化&#xff09;启动5G-A超高可靠性超低时延柔性产线的商用阶段。 在河北保定精工自动化工厂&#xff0c;5G…...

【自动化测试】Java+Selenium自动化测试环境搭建

本主要介绍以Java为基础&#xff0c;搭建Selenium自动化测试环境&#xff0c;并且实现代码编写的过程。 1.Selenium介绍 Selenium 1.0 包含 core、IDE、RC、grid 四部分&#xff0c;selenium 2.0 则是在两位大牛偶遇相互沟通决定把面向对象结构化&#xff08;OOPP&#xff09…...

若依笔记(四):代码生成器

已知使用MyBatisPlus代码生成器可以自动生成Entity、Mapper、Service、Controller代码&#xff0c;前提是数据库中有数据表&#xff0c;生成pojo类以及对于该数据表的增删改查命令的代码&#xff0c;若依更进一步能选择表后生成代码、预览、下载&#xff0c;同时可以生产前端代…...

怎样做好金融投资翻译

我们知道&#xff0c; 金融投资翻译所需的译文往往是会议文献、年终报表、信贷审批等重要企业金融资料&#xff0c;其准确性事关整个企业在今后一段时期内的发展战略与经营成效。尤其像年报&#xff0c;对于上市公司来说更是至关重要的。那么&#xff0c;怎样做好金融投资翻译&…...

ubuntu 分区 方案

ubuntu 分区 方案 自动分区啥样子的&#xff1f; 手动分区 需要怎么操作&#xff1f; 注意点是啥&#xff1f; swap分区 要和 内存大小 差不多 安装ubuntu系统时硬盘分区方案 硬盘分区概述 一块硬盘最多可以分4个主分区&#xff0c;主分区之外的成为扩展分区。硬盘可以没有…...

Python自动化测试面试题总结

python有哪些数据类型怎么将两个字典合并python如何将json写到文件里&#xff1f;在except语句中return后还会不会执行finally中的代码&#xff1f;什么是可变、不可变类型&#xff1f;python函数调用时参数的传递是值传递还是引用传递&#xff1f;python深浅拷贝的区别python为…...

客户端性能测试基础知识

目录 1、客户端性能 1.1、客户端性能基础知识 2、客户端性能工具介绍与环境搭建 2.1.1、perfdog的使用 2.1.2、renderdoc的使用 1、客户端性能 1.1、客户端性能基础知识 客户端性能知识这里对2D和3D类游戏进行展开进行&#xff0c;讲述的有内存、CPU、GPU、帧率这几个模块…...

多模态论文阅读之VLMo

VLMo泛读 TitleMotivationContributionModelExpertimentsSummary Title VLMo:Unified Vision_Langugae Pre-Training with Mixture-of-Modality-Experts Motivation CLIP和ALIGN都采用dual-encoder的方式分别编码图像和文本&#xff0c;模态之间的交互采用cosine similarity…...

休闲类手游还有机会吗?两大策略收割全球玩家

刚刚过去的第三季度&#xff0c;是全球手游市场逆势增长的高光时刻。 买量、营收、下载等多项数据表现优异&#xff0c;其中买量最为突出的产品是休闲类游戏&#xff0c;广告主数占比23.76%断层第一&#xff0c;广告素材占比17.62%&#xff0c;是当之无愧的“广告顶流”。 数…...

Git复制代码

目录 一、常用下载代码 1.登录Git克隆SSH​编辑 2.新建文件然后右键点击Git Bash Here 3.git clone Paste 二. 本地下载 1.从本地进入页面 2.生成代码——>导入——>生成代码后下载 3.解压道相应位置 一、常用下载代码 1.登录Git克隆SSH 2.新建文件然后右键点击…...

数据结构笔记——查找、排序(王道408)

文章目录 查找基本概念线性表查找顺序查找折半查找&#xff08;二分&#xff09;分块查找 树查找二叉排序树&#xff08;BST&#xff09;平衡二叉树&#xff08;AVL&#xff09;的插入平衡化复杂度分析 平衡二叉树的删除 红黑树红黑树的定义和性质红黑树定义红黑树性质 红黑树的…...

MySQL---搜索引擎

MySQL的存储引擎是什么 MySQL当中数据用各种不同的技术存储在文件中&#xff0c;每一种技术都使用不同的存储机制&#xff0c;索引技巧 锁定水平&#xff0c;以及最终提供的不同的功能和能力&#xff0c;这些就是我们说的存储引擎。 MySQL存储引擎的功能 1.MySQL将数据存储在文…...

2022最新版-李宏毅机器学习深度学习课程-P32 Transformer

一、 seq2seq 1. 含义 输入一个序列&#xff0c;机器输出另一个序列&#xff0c;输出序列长度由机器决定。 文本翻译&#xff1a;文本至文本&#xff1b;  语音识别&#xff1a;语音至文本&#xff1b;  语音合成&#xff1a;文本至语音&#xff1b;  聊天机器人&#…...