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;
}
相关推荐
云海听雷20 分钟前
C语言中字符串函数的详细讲解
c语言·笔记·学习
先做个垃圾出来………32 分钟前
汉明距离(Hamming Distance)
开发语言·python·算法
C++ 老炮儿的技术栈43 分钟前
自定义CString类与MFC CString类接口对比
c语言·c++·windows·qt·mfc
人类恶.1 小时前
C 语言学习笔记(数组)
c语言·笔记·学习
小羊在奋斗1 小时前
【LeetCode 热题 100】二叉树的最大深度 / 翻转二叉树 / 二叉树的直径 / 验证二叉搜索树
算法·leetcode·职场和发展
2301_794461572 小时前
力扣-283-移动零
算法·leetcode·职场和发展
编程绿豆侠2 小时前
力扣HOT100之二叉树:98. 验证二叉搜索树
算法·leetcode·职场和发展
技术流浪者2 小时前
C/C++实践(十)C语言冒泡排序深度解析:发展历史、技术方法与应用场景
c语言·数据结构·c++·算法·排序算法
I AM_SUN3 小时前
98. 验证二叉搜索树
数据结构·c++·算法·leetcode
学习中的码虫3 小时前
数据结构基础排序算法
数据结构·算法·排序算法