关于malloc、free、new、delete以及calloc、realloc基本库函数与运载符的含义

2024-04-06 01:18

本文主要是介绍关于malloc、free、new、delete以及calloc、realloc基本库函数与运载符的含义,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在求职的笔试中,发现对malloc、free、new、delete的考察很多,同时也考到了没见过的calloc、realloc库函数,因此还是把这些知识点记录下来,以后方便查阅。

一、malloc和free

malloc和free都是c语言的库函数,一般在stdlib.h中,主要用来进行一段动态内存的分配,包括申请和释放。

malloc的函数原型为Void *malloc(size_t size),主要用于从堆上进行一段内存的申请,返回无类型的指针,需要将返回的指针转换为数据的类型,同时对申请的数据不进行初始化。

free用于将一段指针所指向的内存进行释放,free(p);由于通过malloc申请的内存在系统中记录了长度,因此不需要传入内存的长度。

 

二、malloc、calloc和realloc的比较

malloc的功能如上所述,calloc是用来进行堆空间的内存申请, 函数原型为void *calloc(size_t numElements,size_t sizeOfElement);参数为申请内存元数的个数,以及类型的长度,因此不必计算所要分配的内存的总字节数,同时alloc会对申请的内存进行初始化为0;

malloc和calloc所申请的内存均位于堆空间。malloc由于不需要对所申请的内存进行初始化,因此比calloc的效率要高。

realloc相当于改变指向动态内存区的指针的指向,让它指向新的动态内存地址;函数原型为extern void *realloc(void *mem_address, unsigned int newsize);一般分配了内存之后,如果重新分配内存,当之前分配的内存够用时指针不变,但要分配更大的内存空间时,采用尾部扩展的方式和新开辟一块内存(数据移动了),并返回内存首地址的指针。

 

三、new、delete

new、delete为c++中的库函数,可以用来进行创建对象、分类内存,属于运算符,因此相比malloc能够调用对象的构造函数进行对象内存的申请,可以对非库中的对象进行内存的分类,而malloc则只能针对库中的标准对象进行内存的申请,函数原型为void *operator new(size_t);和void *operator new[](size_t);第二个用于创建数组;

delete用于将new的内存释放,函数原型为void *operator delete(void *),会调用对象的析构函数,释放指针对应的内存,而创建的数组类型则用 *operator delete[](void *)删除。即delete []p;

一般上述的内存分配方式,在进行内存释放时,调用free和delete删除指针p所指向的内存区域之后,最好将p=null,因为此时p属于野指针了,如果后面调用会产生不可预知的错误。


参考:

百度百科


 

 

 

 

 

 



这篇关于关于malloc、free、new、delete以及calloc、realloc基本库函数与运载符的含义的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/878642

相关文章

Go语言中make和new的区别及说明

《Go语言中make和new的区别及说明》:本文主要介绍Go语言中make和new的区别及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1 概述2 new 函数2.1 功能2.2 语法2.3 初始化案例3 make 函数3.1 功能3.2 语法3.3 初始化

Go语言数据库编程GORM 的基本使用详解

《Go语言数据库编程GORM的基本使用详解》GORM是Go语言流行的ORM框架,封装database/sql,支持自动迁移、关联、事务等,提供CRUD、条件查询、钩子函数、日志等功能,简化数据库操作... 目录一、安装与初始化1. 安装 GORM 及数据库驱动2. 建立数据库连接二、定义模型结构体三、自动迁

ModelMapper基本使用和常见场景示例详解

《ModelMapper基本使用和常见场景示例详解》ModelMapper是Java对象映射库,支持自动映射、自定义规则、集合转换及高级配置(如匹配策略、转换器),可集成SpringBoot,减少样板... 目录1. 添加依赖2. 基本用法示例:简单对象映射3. 自定义映射规则4. 集合映射5. 高级配置匹

Oracle 数据库数据操作如何精通 INSERT, UPDATE, DELETE

《Oracle数据库数据操作如何精通INSERT,UPDATE,DELETE》在Oracle数据库中,对表内数据进行增加、修改和删除操作是通过数据操作语言来完成的,下面给大家介绍Oracle数... 目录思维导图一、插入数据 (INSERT)1.1 插入单行数据,指定所有列的值语法:1.2 插入单行数据,指

SQL BETWEEN 语句的基本用法详解

《SQLBETWEEN语句的基本用法详解》SQLBETWEEN语句是一个用于在SQL查询中指定查询条件的重要工具,它允许用户指定一个范围,用于筛选符合特定条件的记录,本文将详细介绍BETWEEN语... 目录概述BETWEEN 语句的基本用法BETWEEN 语句的示例示例 1:查询年龄在 20 到 30 岁

mysql中insert into的基本用法和一些示例

《mysql中insertinto的基本用法和一些示例》INSERTINTO用于向MySQL表插入新行,支持单行/多行及部分列插入,下面给大家介绍mysql中insertinto的基本用法和一些示例... 目录基本语法插入单行数据插入多行数据插入部分列的数据插入默认值注意事项在mysql中,INSERT I

mapstruct中的@Mapper注解的基本用法

《mapstruct中的@Mapper注解的基本用法》在MapStruct中,@Mapper注解是核心注解之一,用于标记一个接口或抽象类为MapStruct的映射器(Mapper),本文给大家介绍ma... 目录1. 基本用法2. 常用属性3. 高级用法4. 注意事项5. 总结6. 编译异常处理在MapSt

Java中Map.Entry()含义及方法使用代码

《Java中Map.Entry()含义及方法使用代码》:本文主要介绍Java中Map.Entry()含义及方法使用的相关资料,Map.Entry是Java中Map的静态内部接口,用于表示键值对,其... 目录前言 Map.Entry作用核心方法常见使用场景1. 遍历 Map 的所有键值对2. 直接修改 Ma

MyBatis ResultMap 的基本用法示例详解

《MyBatisResultMap的基本用法示例详解》在MyBatis中,resultMap用于定义数据库查询结果到Java对象属性的映射关系,本文给大家介绍MyBatisResultMap的基本... 目录MyBATis 中的 resultMap1. resultMap 的基本语法2. 简单的 resul

Java 枚举的基本使用方法及实际使用场景

《Java枚举的基本使用方法及实际使用场景》枚举是Java中一种特殊的类,用于定义一组固定的常量,枚举类型提供了更好的类型安全性和可读性,适用于需要定义一组有限且固定的值的场景,本文给大家介绍Jav... 目录一、什么是枚举?二、枚举的基本使用方法定义枚举三、实际使用场景代替常量状态机四、更多用法1.实现接