副标题#e#
1.calloc(设置内存空间)
相关函数:
malloc,free,realloc,brk
表头文件:
#include <stdlib.h>
界说函数:
void *calloc(size_t nmemb,size_t size);
函数说明:
calloc()用来设置nmemb个相邻的内存单元,每一单元的巨细为size,并返回指向第一个元素的指针。这和利用下列的方法结果沟通:malloc(nmemb*size);不外,在操作calloc()设置内存时会将内存内容初始化为0。
返回值:
若设置乐成则返回一指针,失败则返回NULL。
例一:
#include<stdio.h> #include<stdlib.h> int main(void) { int i; int *pn=(int *)calloc(10,sizeof(int)); for(i=0;i<10;i++) printf("%3d",*pn++); printf("\n"); free(pn); return 0; }
例二:
#include <stdio.h> #include <stdlib.h> #include<string.h> int main(void) { //char *str = NULL; /* 分派内存空间 */ char *str = (char*)calloc(10, sizeof(char)); /* 将hello写入*/ strcpy(str, "Hello"); // http://www.bianceng.cn /*显示变量内容*/ printf("String is %s\n", str); /* 释放空间 */ free(str); return 0; }
#p#副标题#e#
2.free(释放原先设置的内存)
相关函数
malloc,calloc,realloc,brk
表头文件
#include<stdlib.h>
界说函数
void free(void *ptr);
函数说明
参数ptr为指向先前由malloc()、calloc()或realloc()所返回的内存指针。挪用free()后ptr所指的内存空间便会被收回。假使参数ptr所指的内存空间已被收回或是未知的内存地点,则挪用free()大概会有无法预期的环境产生。若参数ptr为NULL,则free()不会有任何浸染。
#include <string.h> #include <stdio.h> #include <malloc.h> #include <stdlib.h> int main(void) { char *str; /* allocate memory for string */ str = (char *)malloc(10); if(str == NULL){ perror("malloc"); exit(1); } /* copy "Hello" to string */ strcpy(str, "Hello"); /* display string */ printf("String is %s\n", str); /* free memory */ free(str); return 0; }
3.getpagesize(取得内存分页巨细)
相关函数:
sbrk
表头文件:
#include<unistd.h>
界说函数:
size_t getpagesize(void);
函数说明:
返回一分页的巨细,单元为字节(byte)。此为系统的分页巨细,不必然会和硬件分页巨细沟通。
返回值:
内存分页巨细。附加说明在Intel x86 上其返回值应为4096bytes。
典型:
#include <stdio.h> #include <unistd.h> main() { printf("page size = %d\n",getpagesize( ) ); }
4.malloc(设置内存空间)
相关函数:
calloc,free,realloc,brk
表头文件:
#include<stdlib.h>
界说函数:
void * malloc(size_t size);
函数说明:
malloc()用来设置内存空间,其巨细由指定的size抉择。
返回值:
若设置乐成则返回一指针,失败则返回NULL。
#include <stdio.h> #include <stdlib.h> main() { int count,*array; /*count是一个计数器,array是一个整型指针,也可以领略为指向一个整型数组的首地点*/ if((array=(int *) malloc (10*sizeof(int)))==NULL) { printf("不能乐成分派存储空间。"); exit(1); } for (count=0;count<10;count++) /*给数组赋值*/ array[count]=count; for(count=0;count<10;count++) /*打印数组元素*/ printf("%2d",array[count]); free(array); }
查察本栏目
5.mmap(成立内存映射)
相关函数:
munmap,open
表头文件:
#include <unistd.h>
#include <sys/mman.h>
界说函数:
void *mmap(void *start,size_t length,int prot,int flags,int fd,off_t offsize);
函数说明:
mmap()用来将某个文件内容映射到内存中,对该内存区域的存取等于直接对该文件内容的读写。参数start指向欲对应的内存起始地点,凡是设为NULL,代表让系统自动选定地点,对应乐成后该地点会返回。参数length代表将文件中多大的部门对应到内存。
参数
prot代表映射区域的掩护方法有下列组合
PROT_EXEC 映射区域可被执行
PROT_READ 映射区域可被读取
PROT_WRITE 映射区域可被写入
PROT_NONE 映射区域不能存取
参数
flags会影响映射区域的各类特性
MAP_FIXED 假如参数start所指的地点无法乐成成立映射时,则放弃映射,差池地点做批改。凡是不勉励用此旗标。
MAP_SHARED对映射区域的写入数据会复制回文件内,并且答允其他映射该文件的历程共享。
#p#分页标题#e#
MAP_PRIVATE 对映射区域的写入操纵会发生一个映射文件的复制,即私人的“写入时复制”(copy on write)对此区域作的任何修改都不会写回本来的文件内容。
MAP_ANONYMOUS成立匿名映射。此时会忽略参数fd,不涉及文件,并且映射区域无法和其他历程共享。
MAP_DENYWRITE只答允对映射区域的写入操纵,其他对文件直接写入的操纵将会被拒绝。
MAP_LOCKED 将映射区域锁定住,这暗示该区域不会被置换(swap)。
在挪用mmap()时必需要指定MAP_SHARED 或MAP_PRIVATE。参数fd为open()返回的文件描写词,代表欲映射到内存的文件。参数offset为文件映射的偏移量,凡是配置为0,代表从文件最前方开始对应,offset必需是分页巨细的整数倍。
返回值
若映射乐成则返回映射区的内存起始地点,不然返回MAP_FAILED(-1),错误原因存于errno 中。
错误代码
EBADF 参数fd 不是有效的文件描写词
EACCES 存取权限有误。假如是MAP_PRIVATE 环境下文件必需可读,利用MAP_SHARED则要有PROT_WRITE以及该文件要能写入。
EINVAL 参数start、length 或offset有一个不正当。
EAGAIN 文件被锁住,或是有太多内存被锁住。
ENOMEM 内存不敷。
#include<unistd.h> #include<sys/mman.h> main() { int fd; void *start; struct stat sb; fd=open("/etc/passwd",O_RDONLY); /*打开/etc/passwd*/ fstat(fd,&sb); /*取得文件巨细*/ start=mmap(NULL,sb.st_size,PROT_READ,MAP_PRIVATE,fd,0); if(start== MAP_FAILED) /*判定是否映射乐成*/ return; printf("%s",start); munmap(start,sb.st_size); /*清除映射*/ close(fd); }
6.munmap(清除内存映射)
相关函数:
munmap
表头文件:
#include<unistd.h>
#include<sys/mman.h>
界说函数:
int munmap(void *start,size_t length);
函数说明:
munmap()用来打消参数start所指的映射内存起始地点,参数length则是欲打消的内存巨细。当历程竣事或操作exec相关函数来执行其他措施时,映射内存会自动清除,但封锁对应的文件描写词时不会清除映射。
返回值:
假如清除映射乐成则返回0,不然返回-1,错误原因存于errno中错误代码EINVAL
参数:
start或length 不正当。
典型
参考mmap()
本文出自 “LinuxQt济南高新区” 博客,请务必保存此出处http://qtlinux.blog.51cto.com/3052744/957661