CPP服务器01--阻塞队列的实现

阻塞队列

1. 实现原理:

  • 容器:std::queue
  • 逻辑:使用一把互斥锁控制队列这个临界资源的访问; 使用条件变量控制入队出队操作(队满则入队阻塞,队空则出队阻塞);
#include "../log/blockqueue.hpp"

#include "pthread.h"
#include <cstdlib>
#include <ctime>
#include <unistd.h>

std::unique_ptr<BlockQueue<std::string>> newbkque(new BlockQueue<std::string>);
std::unique_ptr<BlockQueue<std::string>> bkqueue_ = std::move(newbkque);

void *writeQueue(void *arg) {
    srand(time(0));
    for (int i = 0; i < 2; i++) {
        sleep(rand() % 3);
        bkqueue_->push(std::to_string(i));
    }
}

void *readQueue(void *arg) {
    srand(time(0));
    for (int i = 0; i < 2; i++) {
        sleep(rand() % 2);
        std::string s;
        if (bkqueue_->pop(s, 3)) {
            printf("bkqueue->pop: %s\n", s.c_str());
        } else {
            printf("bkqueue->pop failed\n");
        }

    }
}


int main() {
    for (int i = 0; i < 3; i++) {
        pthread_t tid;
        pthread_create(&tid, NULL, writeQueue, NULL);
        pthread_detach(tid);
    }

    for (int i = 0; i < 5; i++) {
        pthread_t tid;
        pthread_create(&tid, NULL, readQueue, NULL);
        pthread_detach(tid);
    }

    pthread_exit(NULL);

}

2. 功能测试:

  • 多线程入队,多线程出队测试
#include "../log/blockqueue.hpp"

#include "pthread.h"
#include <cstdlib>
#include <ctime>
#include <unistd.h>

std::unique_ptr<BlockQueue<std::string>> newbkque(new BlockQueue<std::string>);
std::unique_ptr<BlockQueue<std::string>> bkqueue_ = std::move(newbkque);

void *writeQueue(void *arg) {
    srand(time(0));
    for (int i = 0; i < 2; i++) {
        sleep(rand() % 3);
        bkqueue_->push(std::to_string(i));
    }
}

void *readQueue(void *arg) {
    srand(time(0));
    for (int i = 0; i < 2; i++) {
        sleep(rand() % 2);
        std::string s;
        if (bkqueue_->pop(s, 3)) {
            printf("bkqueue->pop: %s\n", s.c_str());
        } else {
            printf("bkqueue->pop failed\n");
        }

    }
}


int main() {
    for (int i = 0; i < 3; i++) {
        pthread_t tid;
        pthread_create(&tid, NULL, writeQueue, NULL);
        pthread_detach(tid);
    }

    for (int i = 0; i < 5; i++) {
        pthread_t tid;
        pthread_create(&tid, NULL, readQueue, NULL);
        pthread_detach(tid);
    }

    pthread_exit(NULL);

}

3. CmakeLists.txt

cmake_minimum_required(VERSION 3.20)
project(day01)

set(CMAKE_CXX_FLAGS "${CAMKE_CXX_FLAGS} -std=c++11 -pthread")

add_executable(blockqueue_ex1 examples/blockqueue_ex1.cpp log/blockqueue.hpp)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

ColaForced

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

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

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

打赏作者

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

抵扣说明:

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

余额充值