C语言内存操作函数汇总
【摘要】 一、malloc/calloc名称:Malloc/calloc功能: 动态内存分配函数头文件:#include <stdlib .h>函数原形:void *malloc(size_t size);void *calloc(size_t num,size_t size);参数 : size 分配内存块的大小num 分配内存块的个数返回值: 成功返回分配内存块的首地址,失败返回NULL...
一、malloc/calloc
名称:
|
Malloc/calloc
|
功能:
|
动态内存分配函数
|
头文件:
|
#include <stdlib .h>
|
函数原形:
|
void *malloc(size_t size);
void *calloc(size_t num,size_t size);
|
参数 :
|
size 分配内存块的大小
num 分配内存块的个数
|
返回值:
|
成功返回分配内存块的首地址,失败返回NULL.
|
malloc和calloc都可以分配内存区,但malloc一次只能申请一个内存区,calloc一次可以申请多个内存区.另外calloc会把分配来的内存区初试化为0,malloc不会进行初始化.
#include <stdio.h>
#include <stdlib.h>
main()
{
int *p=NULL;
p=(int *)malloc(sizeof(int));
if(p==NULL)
{
printf("malloc error/n");
exit(1);
}
*p=3;
printf("%d/n",*p);
free(p);
}
|
二、 malloc/calloc
名称:
|
free
|
功能:
|
动态内存释放函数
|
头文件:
|
#include <stdlib .h>
|
函数原形:
|
void free(void *ptr);
|
参数 :
|
ptr 使用malloc或calloc等内存分配函数所返回的内存指针
|
返回值:
|
无
|
free 可以释放由malloc或calloc等内存分配函数分配的内存.当程序很大时,期间可能要多次动态分配内存,如果不及时释放的话,程序将要占用很大内存.
要注意,如果ptr所指内存已被释放或是未知的内存地址,则可能有无法预期的情况发生.若参数为NULL,则free不会有任何作用.
三、 memset
名称:
|
memset
|
功能:
|
初始化所指定的内存空间
|
头文件:
|
#include <stdlib .h>
|
函数原形:
|
void *memset(void *buffer,int c,int count);
|
参数 :
|
buffer 分配的内存
c 初始化内容
count 初始化的字节数
|
返回值:
|
返回指向buffer的指针
|
memset把buffer所指内存区域的前count个字节设置成某个字符的ASCLL值.一般用于给数组,字符串等类型赋值.
main()
{
int *p=NULL;
int i;
char *q=NULL;
p=(int *)malloc(sizeof(int)*10);
if(p==NULL)
exit(1);
memset(p,0,sizeof(int)*10);
q=p;
for(i=0;i<10;i++)
printf("%d",*(q++));
free(p);
}
|
执行结果是10个0.
四、 memcpy
名称:
|
memcpy
|
功能:
|
拷贝内存空间
|
头文件:
|
#include <stdlib .h>
|
函数原形:
|
void *memcpy(void *dest,void *src,unsigned int count);
|
参数 :
|
dest 目标内存区
src 原内存区
count 要复制的字节数
|
返回值:
|
指向dest的指针
|
memcpy会把src所指内存区复制count个字节到dest所指内存区.如果count比src字节数大,strcpy会拷贝'/0'后结束.要注意dest和src不要重叠.
memcpy只是拷贝内存空间,不处理空间重叠的问题.
main()
{
int *p1=NULL;
int *p2=NULL;
int q;
int i;
p1=malloc(sizeof(int)*10);
if(p1==NULL)
exit(1);
p2=malloc(sizeof(int)*5);
if(p2==NULL)
exit(1);
memset(p1,0,sizeof(int)*10);
memcpy(p2,p1,sizeof(int)*5);
q=p2;
for(i=0;i<5;i++)
printf("%d",*(q++));
free(p1);
free(p2);
)
|
运行结果为5个0.
五、 memmove
名称:
|
memmove
|
功能:
|
拷贝(移动)内存空间
|
头文件:
|
#include <stdlib .h>
|
函数原形:
|
void *memmove(void *dest,void *src,unsigned int count);
|
参数 :
|
dest 目标内存区
src 原内存区
count 要复制的字节数
|
返回值:
|
指向dest的指针
|
Memmove和函数memcpy函数功能一样,但只是拷贝内存空间,不处理空间重叠的问题.Memmove会处理空间重叠问题.当dest和src重叠时,仍能正确处理,但src内容发生改变.
六、 memmove
名称:
|
memcmp
|
功能:
|
比较两个内存空间的字符
|
头文件:
|
#include <stdlib .h>
|
函数原形:
|
int memcmp(void *buf1,void *buf2,unsigned int count);
|
参数 :
|
buf1 内存区
buf2 内存区
count 要比较的字符数
|
返回值:
|
见下面
|
Memcmp会比较内存区域buf1和buf2的前count个字节.Memcmp回根据ASCLL码表顺序依次比较.当buf1<buf2时,返回<0;当buf1=buf2时,返回0;当buf1>buf2时,返回>0.
main()
{
int *p1=NULL;
int *p2=NULL;
int rt;
p1=malloc(sizeof(int)*10);
if(p1==NULL)
exit(1);
p2=malloc(sizeof(int)*10);
if(p2==NULL)
exit(1);
memset(p1,'a',sizeof(int)*10);
memset(p2,'b',sizeof(int)*10);
rt=memcmp(p1,p2,sizeof(int)*10);
if(rt>0)
printf("p1>p2);
if(rt<0)
printf("p1<p2");
if(rt==0)
printf("p1=p2");
free(p1);
free(p2);
}
|
运行结果:p1<p2
【版权声明】本文为华为云社区用户原创内容,未经允许不得转载,如需转载请自行联系原作者进行授权。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
cloudbbs@huaweicloud.com
- 点赞
- 收藏
- 关注作者
评论(0)