malloc使用方法

须要包括头文件:

#include 'stdlib.h'

函数声明(函数原型):

void *malloc(int size);

说明:malloc 向系统申请分配指定size个字节的内存空间。返回类型是 void* 类型。void* 表示未确定类型的指针。

C,C++规定,void* 类型能够强制转换为不论什么其他类型的指针。

从函数声明上能够看出。malloc 和 new 至少有两个不同: new 返回指定类型的指针,而且能够自己主动计算所须要大小。比方:

int *p;

p = new int;  /返回类型为int* 类型(整数型指针)。分配大小为 sizeof(int);

或: 

int* parr;

parr = new int [100];   //返回类型为 int* 类型(整数型指针)。分配大小为 sizeof(int) * 100; 

而 malloc 则必须由我们计算要字节数,而且在返回后强行转换为实际类型的指针。 

int* p; 

p = (int *) malloc (sizeof(int)); 

使用事项:

第一、malloc 函数返回的是 void * 类型。假设你写成:p = malloc (sizeof(int)); 则程序无法通过编译。报错:“不能将 void* 赋值给 int * 类型变量”。所以必须通过 (int *) 来将强制转换。

第二、函数的实參为 sizeof(int) 。用于指明一个整型数据须要的大小。假设你写成: 

int* p = (int *) malloc (1);

代码也能通过编译,但其实仅仅分配了1个字节大小的内存空间,当你往里头存入一个整数,就会有3个字节无家可归。而直接“住进邻居家”!造成的结果是后面的内存中原有数据内容所有被清空。

申请出一段连续的内存

malloc 也能够达到 new [] 的效果。申请出一段连续的内存,方法无非是指定你所须要内存大小。

比方想分配100个int类型的空间:

int* p = (int *) malloc ( sizeof(int) * 100 ); //分配能够放得下100个整数的内存空间。

另外有一点不能直接看出的差别是,malloc 仅仅管分配内存。并不能对所得的内存进行初始化,所以得到的一片新内存中,其值将是随机的。

除了分配及最后释放的方法不一样以外,通过malloc或new得到指针。在其他操作上保持一致。

free使用方法

须要包括头文件(和 malloc 一样):

#include 'stdlib.h'

函数声明:

void free(void *block);

即: void free(指针变量);

之所以把形參中的指针声明为 void* 。是由于free必须能够释放随意类型的指针,而随意类型的指针都能够转换为void *。

举例:

int* p = (int *) malloc(4);

*p = 100;

free(p); //释放 p 所指的内存空间

或者:

int* p = (int *) malloc ( sizeof(int) * 100 ); //分配能够放得下100个整数的内存空间。

……

free(p);

free 无论你的指针指向多大的空间,均能够正确地进行释放。这一点释放比 delete/delete [] 要方便。

只是。必须注意。假设你在分配指针时。用的是new或new[],那么抱歉,当你在释放内存时,你并不能图方便而使用free来释放。反过来。你用malloc 分配的内存,也不能用delete/delete[] 来释放。一句话,new/delete、new[]/delete[]、malloc/free 三对均需配套使用。不可混用。

int* p = new int[100];

free(p);      //ERROR! p 是由new 所得。

函数malloc()和calloc()都能够用来动态分配内存空间,但两者稍有差别。

malloc()函数有一个參数,即要分配的内存空间的大小:
void *malloc(size_t size);

calloc()函数有两个參数,分别为元素的数目和每一个元素的大小,这两个參数的乘积就是要分配的内存空间的大小。
void *calloc(size_t numElements,size_t sizeOfElement);

假设调用成功,函数malloc()和函数calloc()都将返回所分配的内存空间的首地址。

函数malloc()和函数calloc()的主要差别是前者不能初始化所分配的内存空间,而后者能。假设由malloc()函数分配的内存空间原来没有被使用过。则当中的每一位可能都是0;反之,假设这部分内存以前被分配过,则当中可能遗留有各种各样的数据。也就是说,使用malloc()函数的程序開始时(内存空间还没有被又一次分配)能正常进行,但经过一段时间(内存空间还已经被又一次分配)可能会出现故障。

函数calloc()会将所分配的内存空间中的每一位都初始化为零,也就是说,假设你是为字符类型或整数类型的元素分配内存,那麽这些元素将保证会被初始化为0;假设你是为指针类型的元素分配内存,那麽这些元素一般会被初始化为空指针;假设你为实型数据分配内存,则这些元素会被初始化为浮点型的零。

须要包括头文件:
#i nclude <mallco.h>

#i nclude <stdlib.h>

malloc使用方法的更多相关文章

  1. 内存泄漏之malloc替换方法

    //内存泄漏之malloc替换方法 //内存泄漏之malloc替换方法#include "stdio.h"#include "stdlib.h" /*文件路径名 ...

  2. Varnish缓存服务

    Varnish缓存服务详解及应用实现   1.varnish的基本介绍   Varnish 的作者Poul-Henning Kamp是FreeBSD的内核开发者之一,他认为现在的计算机比起1975年已 ...

  3. Varnish缓存服务详解及应用实现

    1.varnish的基本介绍    Varnish 的作者Poul-Henning Kamp是FreeBSD的内核开发者之一,他认为现在的计算机比起1975年已经复杂许多.在1975年时,储存媒介只有 ...

  4. 检测Windows程序的内存和资源泄漏之原生语言环境

    最近接连收到大客户的反馈,我们开发的一个软件,姑且称之为App-E吧,在项目规模特别大的情况下,长时间使用会逐渐耗尽内存,运行越来越缓慢,软件最终崩溃.由于App-E是使用混合语言开发的,主界面使用C ...

  5. 深入浅出数据结构C语言版(6)——游标数组及其实现

    在前两次博文中,我们由表讲到数组,然后又由数组的缺陷提出了指针式链表(即http://www.cnblogs.com/mm93/p/6576765.html中讲解的带有next指针的链表).但是指针式 ...

  6. varnish 相关说明

    一.关于Varnish Varnish 是一款高性能且开源的反向代理服务器和 HTTP 加速器,其采用全新的软件体系机构,和现在的硬件体系紧密配合,与传统的 squid 相比,varnish 具有性能 ...

  7. Varnish 初识

    基础 Varnish Cache是​​一种Web应用程序加速器,也称为缓存HTTP反向代理.您将它安装在任何HTTP的服务器前面,并将其配置为缓存内容.Varnish Cache非常非常快.它通常可以 ...

  8. Vanish 详解

    1.varnish 概述:     varnish是一款高性能且开源的方向代理服务器和HTTP加速器,它的开发者poul-Henning kamp FreeBSD 核心的开发人员之一.varnish采 ...

  9. C语言可以分配的最大内存

    前言 最近用C刷PAT算法题目, 发现C语言有太多需要关注大小范围的东西必须 知道, 虽说挺麻烦, 但也挺有意思. int最大值是多少 首先就是int类型的取值范围, 这个太常用. C语言标准规定最低 ...

随机推荐

  1. 1-5html文件基本结构

    认识html文件基本结构 1)这一节中我们来学习html文件的结构:一个HTML文件是有自己固定的结构的. <html> <head>...</head> < ...

  2. 使用EXCEL设置“下拉菜单”选项功能

    原创作品.出自 "深蓝的blog" 博客.欢迎转载.转载时请务必注明出处,否则有权追究版权法律责任. 深蓝的blog:http://blog.csdn.net/huangyanlo ...

  3. myeclipse 那个版本号好用?

    myeclipse 那个版本号好用?   有没有现成的下载地址?

  4. JavaScript发展史,与JScript差别,引入方式,数据类型,命名规范,命名推荐,解决命名冲突

    文件夹: 1.JavaScript发展史 2.JavaScript与JScript差别 3.JavaScript引入方式 4.JavaScript基本数据类型及布尔值 5.JavaScript命名规范 ...

  5. hdu1503(最长公共子序列)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1503 题意:由两个字符串构造出另一个字符串,该字符串包含前两个字符串(按字符顺序,但不一定连续),使该 ...

  6. 服务器编程入门(5)Linux服务器程序规范

    问题聚焦:     除了网络通信外,服务器程序通常还必须考虑许多其他细节问题,这些细节问题涉及面逛且零碎,而且基本上是模板式的,所以称之为服务器程序规范.     工欲善其事,必先利其器,这篇主要来探 ...

  7. SQLServer 复制和数据库镜像 具体配置部署

    SQLserver 能够把镜像和复制同一时候部署,结合了两方的高可用性.能够使数据库得到更好的高可用性和容灾的保证. 关于镜像:f=255&MSPPError=-2147217396" ...

  8. Effective C++:条款38:通过一个复杂的模具has-a要么“基于一些实现”

    (一) public继承是"is-a"关联,"has-a"或"依据某物实现出(is-implemented-in-terms-of)"的意思 ...

  9. SWT的TreeViewer和TableViewer的交互

    左边是一个TreeViewer,右边是一个TableViewer.当点击左边的treeitem的时候,右边的tableViewer要将该item的子节点信息显示出来.就像这样: 左边的treeView ...

  10. hdu1874畅通工程续 (dijkstra)

    Problem Description 某省自从实行了很多年的畅通工程计划后,终于修建了很多路.不过路多了也不好,每次要从一个城镇到另一个城镇时,都有许多种道路方案可以选择,而某些方案要比另一些方案行 ...