【转】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一次可以申请多个内存区.另外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
【转】C内存操作函数的更多相关文章
- c++ void,内存操作函数
void的含义 void的字面意思是“无类型”, void * 则为“无类型指针”, void * 可以指向任何类型的数据 void几乎只有“注释”和限制程序的作用,因为从来没有人会定义一个void变 ...
- c#读写共享内存操作函数封装
原文 c#读写共享内存操作函数封装 c#共享内存操作相对c++共享内存操作来说原理是一样,但是c#会显得有点复杂. 现把昨天封装的读写共享内存封装的函数记录下来,一方面希望给需要这块的有点帮助,另一方 ...
- Delphi中复制带有String的记录结构时不能使用Move之类的内存操作函数
请看下面的代码: program TestRecord; {$APPTYPE CONSOLE} uses SysUtils, Math; type TRecordA = record Na ...
- 内存操作函数memmove,memcpy,memset
通过字符串的学习,我们知道字符串操作函数的操作对象是字符串,并且它的结束标志是结束符\0,当然这个说的是不 受限制的字符串函数.然而当我们想要将一段内存的数据复制到另一块内存时,我们不能使用字符串操作 ...
- C语言中内存操作函数
一.malloc/calloc 名称: Malloc/calloc 功能: 动态内存分配函数 头文件: #include <stdlib.h> 函数原形: void *malloc(s ...
- 自己实现内存操作函数memset(),memcmp(),memcpy(),memmove()
1.memset()内存设置函数(初始化) void *my_memset(void* dest, int c, size_t count) { assert(dest != NULL); char ...
- c语言学习之基础知识点介绍(十九):内存操作函数
一.malloc函数 /* 首先需要导入头文件 #include <stdlib.h> malloc void* malloc(n); n是字节大小 开辟堆空间,开辟的字节数以n为准 返回 ...
- PCI设备内存操作函数总结
1. ExAllocatePool() 函数说明: ExAllocatePool allocates pool memory of the specified type and returns a ...
- Delphi 的内存操作函数(1): 给字符指针分配内存
马上能想到的函数有: GetMem AllocMem ReallocMem FreeMem GetMemory ReallocMemory FreeMemory New Dispose NewStr ...
随机推荐
- HTTP无状态协议
http://baike.baidu.com/view/4551466.htm HTTP协议是无状态协议. 无状态是指协议对于事务处理没有记忆能力.缺少状态意味着如果后续处理需要前面的信息,则它必须重 ...
- JavaScript中使用ActiveXObject操作本地文件夹的方法
转载地址 http://www.jb51.net/article/48538.htm 在Windows平台上, js可以调用很多Windows提供的ActivexObject,本文就使用js来实 ...
- java在window系统的一些问题
一般的, 在windows cmd上启动 utf-8编码的java应用 会有一些字符集问题 可以修改cmd的字符集编码为utf8 , chcp 65001 java -D有空格时 区别: VM参数是 ...
- thinkPHP Model的操作
1.建立一个表 create table Demo( -> id int, ), -> age int, ) -> ); 2.新增数据 2.1面向过程的风格 $d = $a-> ...
- 学习ssm
1.安装配置maven (1)在http://maven.apache.org/download.cgi下载apach-maven-3.5.4-bin.zip (2)将apach-maven-3.5. ...
- ETL的两种架构(ETL架构和ELT架构)
ETL ETL,是英文 Extract-Transform-Load 的缩写,用来描述将数据从来源端经过抽取(extract).转换(transform).加载(load)至目的端的过程.ETL一词 ...
- javassist fr8.0破解
主要是破解连接数的. 已破解的jar:http://download.csdn.net/download/wolf12/9834152 public static void main(String[] ...
- LeetCode 455.分发饼干(C++)
假设你是一位很棒的家长,想要给你的孩子们一些小饼干.但是,每个孩子最多只能给一块饼干.对每个孩子 i ,都有一个胃口值 gi ,这是能让孩子们满足胃口的饼干的最小尺寸:并且每块饼干 j ,都有一个尺寸 ...
- Cloudera Kudu是什么?
不多说,直接上干货! Cloudera Kudu是什么? kudu是cloudera在2012开始秘密研发的一款介于hdfs和hbase之间的高速分布式列式存储数据库.兼具了hbase的实时性.hdf ...
- join() 和 sleep() 区别
来源于<Java多线程编程核心技术> 一.join() 作用 在很多情况,主线程创建并启动子线程,如果子线程中需要进行大量的耗时计算,主线程往往早于子线程结束.这时,如果主线程想等待子线程 ...