Chapter7 内存分配
本章将用于在堆或者栈上分配内存的函数。
7.1 在堆上分配内存
通常将堆的当前的内存边界称为"program break"

7.1.1 调整program break: brk()和sbrk()
改变堆的大小(即分配或者释放内存),其实就像命令内核改变进程的program break位置一样简单。
传统的UNIX系统提供了两个操纵program break的系统调用:brk()和sbrk().
#include <unistd.h>
int brk(void *end_data_segmeng);
void *sbrk(intptr_t increment);

7.1.2 在堆上分配内存:malloc()和free()
一般情况下,C语言使用malloc函数族在对上分配和释放内存。比较brk()和sbrk(),具有以下优点
(1):属于C语言标准部分
(2):更易于在多线程中使用
(3):接口简单,允许分配小块内存
(4):允许随意释放内存块,他们被维护在于一个空闲的内存列表中,在后续内存分配调用是循环使用。

#include <stdlib.h>
void *malloc(size_t size);
malloc()返回内存块所采用字节对齐方式,总是适用于高效访问任何类型的C语言数据结构。在大多数硬件结构上,这意味着malloc是基于8字节或16字节边界来分配内存的。

free()函数释放ptr参数所指向的内存块,该参数应该是之前由malloc().
#include <stdlib.h>
void free(void *ptr);

7.1.3 malloc()和free()的实现

malloc()调试的工具和库

7.1.4 在堆上分配内存的其他方法
用calloc()和realloc()分配内存
#include <stdlib.h>
void *calloc(size_t numitms, size_t size);
numitms:指定分配对象的数量
size:指定每个对象的大小
注意:calloc()会将分配的内存初始化为0,而malloc()返回的是为初始化的内存空间。
eg:
struct { /**/}myStruct;
struct myStruct *p;

p = calloc(1000, sizeof(struct myStruct));
if(p == NULL)
errExit("calloc");

realloc()函数用来调整(通常是增加)一块内存的大小,而此块内存应该是之前由malloc包中函数所分配的。
#include <stdlib.h>
void *realloc(void *ptr, size_t size);
realloc()增加了已分配的内存块的大小,则不会对额外分配的字节进行初始化。
使用calloc() 和realloc()分配的内存应使用free()来释放。

分配对齐的内存:memalign()和posix_memalign()
目的:在分配内存的时候,起始地址要与2的整数次幂边界对齐。
#include <malloc.h>
void *memalign(size_t boundary, size_t size);
作用:分配size个字节的内存,起始地址的参数boundary的整数倍,而boundary必须是2的整数次幂。

posix_memalign(),该函数由标准委员会于近期创建,只是出现在了少数UNIX实现上。
#include <stdlib.h>
int posix_memalign(void **memptr, size_t alignment, size_t size);

7.2 在堆栈上分配内存:alloca()
alloca()也可以动态分配内存,不过不是从堆上分配内存,而是通过增加栈帧的大小从堆栈上分配。
#include <alloca.h>
void *alloca(size_t size);
注意:不需要(实际上也决不能)调用free()来释放由alloca分配的内存。同样也不能调用realloc()来调整由alloca()分配的内存大小。
不能再一个函数的参数列表中调用alloca().

【Linux_Unix系统编程】chapter7 内存分配的更多相关文章

  1. 【Linux_Unix系统编程】chapter6 进程

    chapter6 进程 重点关注进程虚拟内存的布局及内容.6.1 进程和程序 进程(process)是一个可执行程序(program)的实例. 程序是包含了一系列信息的文件,这些信息描述了如何在运行时 ...

  2. 【Linux_Unix系统编程】Chapter4 文件IO

    Chapter4 文件IO 4.1 概述 文件描述符 == Windows的句柄 标准文件描述符: 0 标准输入 STDIN_FILENO stdin 1 标准输出 STDOUT_FILENO std ...

  3. 【Linux_Unix系统编程】Chapter10 时间

    chapter10 时间 1:真实时间:度量这一时间的起点有二:(1)某个标准点:(2)进程生命周期内的某个固定时点(通常为程序启动) 2:进程时间:一个进程所使用的CPU时间总量,适用于对程序,算法 ...

  4. 【Linux_Unix系统编程】Chapter9 进程凭证

    chapter9 进程凭证 每个进程都有一套用数字表示的用户ID(UID)和组ID(GID).有时也将这些ID称子为进程凭证. 1:实际用户ID和实际组ID 2:有效用户ID和有效组ID 3:保存的s ...

  5. 【Linux_Unix系统编程】Chapter8 用户和组

    chapter8 用户和组 8.1 密码文件 /etc/passwd 每行都包含7个字段,之间用冒号分割,如下所示: mtk:x:1000:100:Michael:/home/mtk:/bin/bas ...

  6. 【Linux_Unix系统编程】chapter5 深入探究文件IO

    Chapter5 深入探究文件I/O 本章节将介绍另一个与文件操作相关的系统调用:多用途的fcntl(),并展示其应用之一读取和设置打开文件的状态标志. 5.1 原子操作和竞争条件 所有系统调用都是以 ...

  7. Linux系统编程 —共享内存之mmap

    共享内存概念 共享内存是通信效率最高的IPC方式,因为进程可以直接读写内存,而无需进行数据的拷备.但是它没有自带同步机制,需要配合信号量等方式来进行同步. 共享内存被创建以后,同一块物理内存被映射到了 ...

  8. Win内存分配函数(GlobalAlloc/HeapAlloc/LocalAlloc/VirtualAlloc)

    Win内存分配函数(GlobalAlloc/HeapAlloc/LocalAlloc/VirtualAlloc) 来源:http://blog.csdn.net/chunyexiyu/article/ ...

  9. 全面介绍Windows内存管理机制及C++内存分配实例

    转自:http://blog.csdn.net/yeming81/article/details/2046193 本文基本上是windows via c/c++上的内容,笔记做得不错.. 本文背景: ...

随机推荐

  1. Incremental Method

    「遞增法」是符合電腦運作特性的方法.電腦執行程式,一次只做一個動作,完成了一件事才做下一件事.當一個問題太大太多時,化整為零.一個一個解決吧! 合抱之木,生於毫末:九層之臺,起於累土:千里之行,始於足 ...

  2. 弹出的ViewController半透明效果

    在第一个ViewController做如下设置 let controller = UIStoryboard(name: "Main", bundle: nil).instantia ...

  3. SWIFT中用Switch case 类类型

    有时觉得SWIFT的语法真的强大而又变态,不说了,直接上代码瞅瞅: 首先先定义一个交通工具的父类 class Vehicle{ var wheels:Int! var speed:Double! in ...

  4. Vue.js使用v-show和v-if的注意事项

    这篇文章一开始先对Vue.js中v-show和v-if两者的区别进行了简单的介绍,而后通过图文详细给大家介绍了Vue.js使用v-show和v-if注意的事项,有需要的朋友们可以参考借鉴,下面来一起看 ...

  5. BZOJ5340: [Ctsc2018]假面【概率+期望】【思维】

    LINK 思路 首先考虑减血,直接一个dp做过去,这个部分分不难拿 然后是\(op=1\)的部分 首先因为要知道每个人被打的概率,所以需要算出这个人活着的时候有多少个人活着时概率是什么 那么用\(g_ ...

  6. TP框架连接mongodb报错及解决办法

    mongodb版本3.4.7 1.认证错误:Failed to connect to: localhost:27017: Authentication failed on database 'test ...

  7. 辞树的QAQ水题(字符串统计,思维)

    思路:统计一串字符有多少个'A',并分别统计出每个'A'前后有多少'Q'.然后让每个'A'前后的'Q'相乘并相加就能得出结果了. 注意:数据的类型,卡了int,要用long long. 还有就是在pc ...

  8. CTF-练习平台-Social之 密码?

    一.密码? 看到题目提示是“张三”“生日”,再联系到我们设置密码时一般是名字的拼音首字母加生日,所以猜测是:zs19970315尝试后正确.

  9. Memcached 真的过时了吗?

    这两年Redis火得可以,Redis也常常被当作Memcached的挑战者被提到桌面上来.关于Redis与Memcached的比较更是比比皆是.然而,Redis真的在功能.性能以及内存使用效率上都超越 ...

  10. WPF如何用TreeView制作好友列表、播放列表(转)

    WPF如何用TreeView制作好友列表.播放列表 前言 TreeView这个控件对于我来说是用得比较多的,以前做的小聊天软件(好友列表).音乐播放器(播放列表).类库展示器(树形类结构)等都用的是T ...