C语言实现内存池管理可用于嵌入式设备

C语言实现的内存池并管理


C语言标准库malloc函数的效率是很低的,一般在嵌入式设备上是比较要求效率,所以在嵌入式小型系统中,可以开辟一个大一点的数组,通过管理该数组模拟内存释放的功能,以此来提高内存申请和释放的效率。


【头文件】

/*
 * malloc.h
 *
 *  Created on: 2019年11月26日
 *      Author: AnKun
 */

#ifndef MALLOC_H_
#define MALLOC_H_

#ifndef NULL
#define NULL 0
#endif

#define MEM_BLOCK_SIZE		32											// 内存块大小
#define MEM_BLOCK_NUMS		1024										// 内存块数目
#define MEM_MAX_SIZE		(MEM_BLOCK_SIZE * MEM_BLOCK_NUMS)		// 内存池大小,32*1024=32KB

// 内存池初始化
void mem_init(void);

// 内存释放
void mem_free(void* p);

// 内存申请
void* mem_malloc(unsigned int size);

// 重新调整已有内存大小
void* mem_realloc(void* p, unsigned int size);

// 获得内存使用率
float mem_perused(void);

// 内存设置
void mem_memset(void* dst, unsigned char val, unsigned int size);

// 内存拷贝
void mem_memcpy(void* dst, const void* src, unsigned int size);

// 获得内存使用量
unsigned int mem_getused(void);

// 获得内存空余量
unsigned int mem_getfree(void);

// 获得内存大小
unsigned int mem_getsize(void);

#endif /* MALLOC_H_ */

【源文件】

/*
 * malloc.c
 *
 *  Created on: 2019年11月26日
 *      Author: AnKun
 */


#include "malloc.h"

__attribute__((aligned(4)))  unsigned char memory[MEM_MAX_SIZE];
__attribute__((aligned(4)))  unsigned short memtbl[MEM_BLOCK_NUMS];

/**
 * 内存拷贝函数
 * @param dst  目标地址
 * @param src  源地址
 * @param size 拷贝大小
 */
void mem_memcpy(void* dst, const void* src, unsigned int size)
{
	char* d = (char *)dst;
	const char* s = (char *)src;

	while (size >= sizeof(int))
	{
		*(int *)d = *(int *)s;
		d += sizeof(int);
		s += sizeof(int);
		size -= sizeof(int);
	}

	while (size--)
	{
		*d++ = *s++;
	}
}

/**
 * 内存设置函数
 * @param dst  目标地址
 * @param val  要设置的值
 * @param size 内存连续设置的长度
 */
void mem_memset(void* dst, unsigned char val, unsigned int size)
{
	unsigned int value = 0;
	unsigned char* p = (unsigned char *)dst;

	value =  (val << 24) | (val << 16) | (val << 8) | val;

	while (size >= sizeof(int))
	{
		*(unsigned int *)p = value;
		p += sizeof(int);
		size -= sizeof(int);
	}

	while (size--)
	{
		*p++ = val;
	}
}

/**
 * 内存申请函数,申请的内存空间会被初始化为0
 * @param size 要申请的大小
 * @return     申请成功返回内存地址,失败返回NULL
 */
void* mem_malloc(unsigned int size)
{
	int i = 0, k = 0;
	unsigned int nblocks = 0, cblocks = 0;
	unsigned char* p = NULL;

	if (!size)  return NULL;

	nblocks = (size % MEM_BLOCK_SIZE) == 0 ? (size / MEM_BLOCK_SIZE) : (size / MEM_BLOCK_SIZE + 1);

	for (i = 0; i != MEM_BLOCK_NUMS; i++)
	{
		cblocks = memtbl[i] == 0 ? (cblocks + 1) : 0;
		if (cblocks == nblocks)
		{
			for (k = 0; k != nblocks; k++)
			{
				memtbl[i - k] = nblocks;
			}
			p = (unsigned char *)(memory + (i + 1 - nblocks) * MEM_BLOCK_SIZE);
			mem_memset(p, 0, nblocks * MEM_BLOCK_SIZE);
			return (void *)p;
		}
	}
	return NULL;
}

/**
 * 重新申请内存
 * 注意:若newSize > p的size,则会造成p的多余部分内容丢失;若p为空地址,则等效于mem_malloc函数
 * @param p     旧地址
 * @param size  重新申请的大小
 * @return      新地址
 */
void* mem_realloc(void* p, unsigned int newSize)
{
	unsigned int index;
	unsigned int oldSize;
	unsigned char* newAddr = NULL;

	if (!p)  return mem_malloc(newSize);

	index = (((unsigned int)p) - ((unsigned int)memory)) / MEM_BLOCK_SIZE;
	oldSize = memtbl[index] * MEM_BLOCK_SIZE;

	if ((newAddr = mem_malloc(oldSize)) != NULL)
	{
		mem_memcpy(newAddr, p, newSize > oldSize ? oldSize : newSize);
		mem_free(p);
		return (void *)newAddr;
	}
	return NULL;
}

/**
 * 内存释放函数
 * @param p 要释放的内存地址
 */
void mem_free(void* p)
{
	int i;
	unsigned int index;
	unsigned int nblocks;

	if (!p) return;
	if (((unsigned int)p) < ((unsigned int)memory) || ((unsigned int)p) > ((unsigned int)(memory + MEM_MAX_SIZE - 1)))  return;

	index = (((unsigned int)p) - ((unsigned int)memory)) / MEM_BLOCK_SIZE;
	nblocks = memtbl[index];
	for (i = 0; i != nblocks; i++)
	{
		memtbl[index + i] = 0;
	}
}

/**
 * 获得内存使用率
 */
float mem_perused(void)
{
	unsigned int i = 0;
	unsigned int used = 0;
	for (i = 0; i != MEM_BLOCK_NUMS; i++)
	{
		if (memtbl[i] != 0)  used++;
	}
	return (((float)(used * 100)) / ((float)MEM_BLOCK_NUMS));
}

/**
 * 获得内存使用量
 */
unsigned int mem_getused(void)
{
	unsigned int i = 0;
	unsigned int used = 0;
	for (i = 0; i != MEM_BLOCK_NUMS; i++)
	{
		if (memtbl[i] != 0)  used++;
	}
	return used * MEM_BLOCK_SIZE;
}

/**
 * 获得内存空余量
 */
unsigned int mem_getfree(void)
{
	unsigned int i = 0;
	unsigned int free = 0;
	for (i = 0; i != MEM_BLOCK_NUMS; i++)
	{
		if (!memtbl[i])  free++;
	}
	return free * MEM_BLOCK_SIZE;
}

/**
 * 获得内存池总大小
 */
unsigned int mem_getsize(void)
{
	return sizeof(memory);
}

/**
 * 内存池初始化函数
 */
void mem_init(void)
{
	mem_memset(memory, 0, sizeof(memory));			// 初始化内存池
	mem_memset(memtbl, 0, sizeof(memtbl));			// 初始化内存索引表
}

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
这个采用C语言开发的项目是一个多功能的软件应用程序。它旨在提供一个高效、可靠的解决方案,用于处理各种计算机科学和软件开发任务。该项目的目标是为开发人员和计算机科学专业人员提供一个功能强大且易于使用的工具集。 该项目具有许多令人印象深刻的特性。首先,它提供了一组丰富的库和工具,以支持C语言的开发和调试。这些库包括用于字符串处理、内存管理、文件操作和网络编程等常见任务的函数。此外,该项目还提供了一套强大的调试工具,帮助开发人员快速定位和修复代码中的错误。 另一个令人赞赏的特点是该项目的跨平台性。它可以在多个操作系统上运行,包括Windows、Linux和Mac OS等。这使得开发人员可以在不同的环境中使用同一套工具和库,从而提高了开发的灵活性和效率。 该项目还具有高度可定制性。开发人员可以根据自己的需求和偏好,灵活地配置和扩展项目的功能。这包括选择所需的库、启用或禁用特定的功能模块以及修改项目的行为。 此外,该项目还注重性能和效率。通过优化算法和数据结构,以及利用硬件资源的最佳方,该项目能够在处理大规模数据和复杂计算时提供出色的性能。 总之,这个采用C语言开发的项目是一个强大而灵活的工具,为开发人员和计算机科学专业人员提供了丰富的功能和可靠的解决方案。它的跨平台性、可定制性和高性能使其成为一个理想的选择,无论是进行系统编程、嵌入开发还是进行科学计算和数据处理。
在了解实时嵌入操作系统内存管理机制的特点以及实时处理对内存管理需求的基础上,练习并掌握有效处理内存碎片的内存管理机制,同时理解防止内存泄漏问题的良好设计方法。 管理系统是一种通过计算机技术实现用于组织、监控和控制各种活动的软件系统。这些系统通常被设计用来提高效率、减少错误、加强安全性,同时提供数据和信息支持。以下是一些常见类型的管理系统: 学校管理系统: 用于学校或教育机构的学生信息、教职员工信息、课程管理、成绩记录、考勤管理等。学校管理系统帮助提高学校的组织效率和信息管理水平。 人力资源管理系统(HRM): 用于处理组织内的人事信息,包括员工招聘、培训记录、薪资管理、绩效评估等。HRM系统有助于企业更有效地管理人力资源,提高员工的工作效率和满意度。 库存管理系统: 用于追踪和管理商品或原材料的库存。这种系统可以帮助企业避免库存过剩或不足的问题,提高供应链的效率。 客户关系管理系统(CRM): 用于管理与客户之间的关系,包括客户信息、沟通记录、销售机会跟踪等。CRM系统有助于企业更好地理解客户需求,提高客户满意度和保留率。 医院管理系统: 用于管理医院或医疗机构的患者信息、医生排班、药品库存等。这种系统可以提高医疗服务的质量和效率。 财务管理系统: 用于记录和管理组织的财务信息,包括会计凭证、财务报表、预算管理等。财务管理系统
嵌入C语言是C标准委员会指定的C编程语言的一组语言扩展,通常用于解决不同嵌入系统的C扩展之间存在的共性问题。它需要对C语言进行非标准扩展,以支持增强的微处理器功能,如定点算术、多个不同的内存库和基本I/O操作。与C++相比,C语言更加简洁和轻量级,适用于嵌入系统开发。\[1\] 堆是用于程序动态申请分配和释放空间的一种内存区域。在C语言中,可以使用malloc和free函数,在C++中可以使用new和delete操作符来在堆中进行内存分配和释放。堆中的空间需要程序员手动释放,否则在程序结束后由系统自动回收。需要注意的是,这里的堆并不是数据结构中的堆。\[2\] 嵌入系统开发需要对硬件和软件进行深入理解,并结合特定的项目需求进行设计和实现。通过不断学习和实践,可以提高嵌入开发技能,开发出高效、稳定的嵌入系统。\[3\] #### 引用[.reference_title] - *1* *2* [嵌入C基础知识(1)](https://blog.csdn.net/xiaoyi9812/article/details/128920427)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [嵌入系统开发:使用C语言进行嵌入编程](https://blog.csdn.net/m0_75198698/article/details/130715374)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

觉皇嵌入式

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值