C语言-简单的缓冲池(Buffer Pool)的源码示例

概述

用C语言实现,缓冲池用于管理一组固定大小的缓冲区,并提供分配和释放缓冲区的功能。

cpp 复制代码
#include <stdio.h>
#include <stdint.h>
#include <stdbool.h>

#define BUFFER_SIZE 64
#define POOL_SIZE   10

// 定义缓冲区结构体
typedef struct {
    uint8_t data[BUFFER_SIZE];
    bool inUse;
} Buffer;

// 定义缓冲池结构体
typedef struct {
    Buffer buffers[POOL_SIZE];
} BufferPool;

// 初始化缓冲池
void initBufferPool(BufferPool* pool) 
{
    for (int i = 0; i < POOL_SIZE; ++i) {
        pool->buffers[i].inUse = false;
    }
}

// 分配缓冲区
uint8_t* allocateBuffer(BufferPool* pool) 
{
    for (int i = 0; i < POOL_SIZE; ++i) {
        if (!pool->buffers[i].inUse) {
            pool->buffers[i].inUse = true;
            return pool->buffers[i].data;
        }
    }
    // 没有可用的缓冲区
    return NULL;
}

// 释放缓冲区
void freeBuffer(BufferPool* pool, uint8_t* buffer) 
{
    for (int i = 0; i < POOL_SIZE; ++i) {
        if (pool->buffers[i].data == buffer) {
            pool->buffers[i].inUse = false;
            return;
        }
    }
    // 找不到对应的缓冲区
    printf("Failed to free buffer: Buffer not found\n");
}

int main(void)
{
    BufferPool pool;
    initBufferPool(&pool);

    // 分配缓冲区
    uint8_t* buffer1 = allocateBuffer(&pool);
    if (buffer1 != NULL) {
        // 使用缓冲区
        // ...
        // 释放缓冲区
        freeBuffer(&pool, buffer1);
    }

    // 分配另一个缓冲区
    uint8_t* buffer2 = allocateBuffer(&pool);
    if (buffer2 != NULL) {
        // 使用缓冲区
        // ...
        // 释放缓冲区
        freeBuffer(&pool, buffer2);
    }

    return 0;
}
相关推荐
小O的算法实验室1 小时前
2025年IEEE TETCI,异构无人机取送货问题中的转运优化,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
chao1898447 小时前
基于 SPEA2 的多目标优化算法 MATLAB 实现
开发语言·算法·matlab
沪漂阿龙7 小时前
AI大模型面试题:支持向量机是什么?间隔最大化、软间隔、核函数、LinearSVC 全面拆解
人工智能·算法·支持向量机
難釋懷7 小时前
Redis数据结构-Set结构
数据结构·redis·bootstrap
little~钰8 小时前
倍增算法和ST表
算法
知识领航员9 小时前
蘑兔AI音乐深度实测:功能拆解、实测表现与适用场景
java·c语言·c++·人工智能·python·算法·github
薛定e的猫咪9 小时前
因果推理研究方向综述笔记
人工智能·笔记·深度学习·算法
如何原谅奋力过但无声10 小时前
【灵神高频面试题合集06-08】反转链表、快慢指针(环形链表/重排链表)、前后指针(删除链表/链表去重)
数据结构·python·算法·leetcode·链表
平行侠10 小时前
037插入排序 - 整理扑克牌的算法
数据结构·算法