char *str=(char *)malloc(sizeof(char)*100); //相当于静态字符数组str[100],但大小可以更改的
typedef struct pointer { int data; struct pointer *p; } pp;
pp *p=(pp *)malloc(sizeof(struct pointer)); //动态申请结构体空间
其他几个函数是队申请空间的修改的操作根据定义自己可以试试
再一个版本:
一:它们都是动态分配内存,先看看它们的原型:
void *malloc( size_t size ); //分配的大小
void *calloc( size_t numElements, size_t sizeOfElement ); // 分配元素的个数和每个元素的大小
共同点就是:它们返回的是 void * 类型,也就是说如果我们要为int或者其他类型的数据分配空间必须显式强制转换;
不同点是:用malloc分配存储空间时,必须由我们计算需要的字节数。如果想要分配5个int型的空间,那就是说需要5*sizeof(int)的内存空间:
int * ip_a; ip_a = (int*)malloc( sizeof (int) * 5 );
而用calloc就不需要这么计算了,直接:

ip_a = ( int* )calloc( 5, sizeof(int) );这样,就分配了相应的空间,而他们之间最大的区别就是:用malloc只分配空间不初始化,也就是依然保留着这段内存里的数据,而calloc则进行了初始化,calloc分配的空间全部初始化为0,这样就避免了可能的一些数据错误。
先写段代码体验体验....
#include <iostream>
using namespace std;
void main() { int * ip_a; int * ip_b;
ip_a = (int*)malloc( sizeof (int) * 5 ); for( int i = 0; i < 5; i++ ) { cin>>ip_a[i]; } for( int j = 0; j < 5; j++ ) { cout<<ip_a[j]<<" "; }
ip_b = ( int* )calloc( 5, sizeof(int) ); for( int j = 0; j < 5; j++ ) { cout<<ip_b[j]<<" "; }
}
这个输出就能够清晰的看出他们的不同....
++版:
它们的返回值都是请求系统分配的地址,如果请求失败就返回NULL
malloc用于申请一段新的地址,参数size为需要内存空间的长度,如: char* p; p=(char*)malloc(20);
calloc与malloc相似,参数sizeOfElement为申请地址的单位元素长度,numElements为元素个数,如: char* p; p=(char*)calloc(20,sizeof(char)); 这个例子与上一个效果相同
注意,这里的空间长度都是以字节为单位。
C语言的标准内存分配函数:malloc,calloc,realloc,free等。 malloc与calloc的区别为1块与n块的区别: malloc调用形式为(类型*)malloc(size):在内存的动态存储区中分配一块长度为“size”字节的连续区域,返回该区域的首地址。 calloc调用形式为(类型*)calloc(n,size):在内存的动态存储区中分配n块长度为“size”字节的连续区域,返回首地址。 realloc调用形式为(类型*)realloc(*ptr,size):将ptr内存大小增大到size。 free的调用形式为free(void*ptr):释放ptr所指向的一块内存空间。 C++中为new/delete函数。
本文来自电脑杂谈,转载请注明本文网址:
http://www.pc-fly.com/a/jisuanjixue/article-23735-2.html
考虑去演戏吧
中国的电器5年内维修率超过50%