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;
}
相关推荐
LNTON羚通22 分钟前
摄像机视频分析软件下载LiteAIServer视频智能分析平台玩手机打电话检测算法技术的实现
算法·目标检测·音视频·监控·视频监控
哭泣的眼泪4082 小时前
解析粗糙度仪在工业制造及材料科学和建筑工程领域的重要性
python·算法·django·virtualenv·pygame
Microsoft Word3 小时前
c++基础语法
开发语言·c++·算法
天才在此3 小时前
汽车加油行驶问题-动态规划算法(已在洛谷AC)
算法·动态规划
莫叫石榴姐4 小时前
数据科学与SQL:组距分组分析 | 区间分布问题
大数据·人工智能·sql·深度学习·算法·机器学习·数据挖掘
茶猫_5 小时前
力扣面试题 - 25 二进制数转字符串
c语言·算法·leetcode·职场和发展
ö Constancy5 小时前
Linux 使用gdb调试core文件
linux·c语言·vim
lb36363636365 小时前
介绍一下strncmp(c基础)
c语言·知识点
wellnw5 小时前
[linux] linux c实现共享内存读写操作
linux·c语言
Hera_Yc.H6 小时前
数据结构之一:复杂度
数据结构