c语言接口与实现--内存管理章节理解,含实例

本文深入探讨《c语言接口与实现–创建可重用软件技术》第5章的内存管理,讲解了如何通过mem.c和memchk.c实现内存分配与回收。强调了正确处理内存管理的重要性,以防内存泄漏和系统崩溃。文章详细解析了内存分配的实现,包括联合体的作用、哈希表的哈希值计算,以及内存分配和释放的策略。此外,还讨论了内存管理的局限性和可能的改进,如合并相邻空闲块以优化内存利用率。

《c语言接口与实现–创建可重用软件技术》人邮版第5章–内存管理,本章节涉及到c语言的内存分配与回收,内存管理在c语言中尤为重要,如果处理不当,会造成内存泄漏甚至系统崩溃的严重问题。本章介绍了一种内存管理方法的实现。比较难懂,需要结合图形来理解。
书中给出了两个源码mem.c和memchk.c, mem.c为简单的实现,是一般的使用方式;memchk.c是本章的精髓,还是先上完整的代码,然后逐步阐述我对代码的理解,如有错误请指正。

mem.h,我的except.h放在公共的include里面,而且做成了libexcept.so,后续的章节基本都会用到这个异常库。

#ifndef MEM_INCLUDED
#define MEM_INCLUDED

#include "../../include/except.h"

extern const Except_T Mem_Failed;
extern void *Mem_alloc(long nbytes, const char *file, \
            int line);
extern void *Mem_calloc(long count, long nbytes,     \
            const char * file, int line);

extern void Mem_free(void *ptr, const char *file, int line);

extern void *Mem_resize(void *ptr, long nbytes, const char *file, int line);



#define ALLOC(nbytes)  \
        Mem_alloc((nbytes), __FILE__, __LINE__)

#define CALLOC(count, nbytes)   \
        Mem_calloc((count), (nbytes), __FILE__, __LINE__)

#define NEW(p)  ((p) = ALLOC((long)sizeof*(p)))

#define NEW0(p)  ((p) = CALLOC(1, (long)sizeof*(p)))

#define FREE(ptr)   ((void) (Mem_free((ptr),  \
        __FILE__, __LINE__), (ptr) = 0))

#define RESIZE(ptr, nbytes) ((ptr) = Mem_resize((ptr),  \
        (nbytes), __FILE__, __LINE__))



#endif

memchk.c

#include <stdlib.h>
#include <string.h>
#include "assert.h"
#include "except.h"
#include "men.h"

// size 12 in 32bit system
union align 
{
    int i;
    long l;
    long *lp;
    void *p;
    void (*fp)(void);
    float f;
    double d;
    long double ld;
};

// get hash value [0,sizeof(t)/sizeof((t)[0]) - 1]
// if t = htab value [0,2046]
#define hash(p, t)  (((unsigned long) (p) >> 3) & \
        (sizeof (t)/sizeof((t)[0])-1))

// except info
const struct Except_T Mem_Failed = {
  
  "Allocation Failed"};

// mem list
static struct descriptor 
{
    struct descriptor *free;
    struct descriptor *link;
    const void *ptr;
    long size;
    const char *file;
    int line;
} *htab[2048];

// descriptor unit
static struct descriptor freelist = {&freelist};

static struct descriptor *find(const void *ptr)
{
    struct descriptor *bp = htab[hash(ptr, htab)];

    while( bp && bp->ptr != ptr )
    {
        bp = bp->link;
    }
    return bp;
}

void Mem_free(void *ptr, const char *file, int line) 
{
    if (ptr)
    {
        struct descriptor *bp;

        if (((unsigned long )ptr)%(sizeof(union align))!=<
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值