欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C++單例模式實現線程池的示例代碼

 更新時間:2023年04月20日 16:38:17   作者:Michael_Good  
這篇文章主要為大家詳細介紹了如何利用C++單例模式簡單實現一個線程池,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起了解一下

C語言單例模式實現線程池。

該代碼中,使用了單例模式來創(chuàng)建線程池對象,保證了整個程序中只有一個線程池對象。

線程池中包含了任務隊列、工作線程數組、互斥鎖、條件變量等成員,通過這些成員來實現任務的提交和執(zhí)行。

在主函數中,提交了10個任務,每個任務都是一個簡單的打印數字的函數,最后等待所有任務執(zhí)行完畢后銷毀線程池。

#include <stdio.h>
#include <stdlib.h>
#include <pthread.h>

#define THREAD_POOL_SIZE 5

// 任務結構體
typedef struct {
    void (*task)(void*);
    void* arg;
} Task;

// 線程池結構體
typedef struct {
    Task* tasks; // 任務隊列
    int size; // 任務隊列大小
    int head; // 任務隊列頭指針
    int tail; // 任務隊列尾指針
    int count; // 任務隊列中任務數量
    pthread_mutex_t lock; // 互斥鎖
    pthread_cond_t not_empty; // 非空條件變量
    pthread_cond_t not_full; // 非滿條件變量
    int shutdown; // 線程池是否關閉
    pthread_t* threads; // 工作線程數組
    int thread_count; // 工作線程數量
} ThreadPool;

// 線程池單例結構體
typedef struct {
    ThreadPool* pool; // 線程池指針
} ThreadPoolSingleton;

static ThreadPoolSingleton* instance = NULL; // 線程池單例對象指針

// 工作線程函數
void* worker(void* arg) {
    ThreadPool* pool = (ThreadPool*)arg;
    while (1) {
        pthread_mutex_lock(&pool->lock);
        while (pool->count == 0 && !pool->shutdown) {
            pthread_cond_wait(&pool->not_empty, &pool->lock);
        }
        if (pool->count == 0 && pool->shutdown) {
            pthread_mutex_unlock(&pool->lock);
            pthread_exit(NULL);
        }
        Task task = pool->tasks[pool->head];
        pool->head = (pool->head + 1) % pool->size;
        pool->count--;
        pthread_cond_signal(&pool->not_full);
        pthread_mutex_unlock(&pool->lock);
        task.task(task.arg);
    }
    return NULL;
}

// 創(chuàng)建線程池函數
ThreadPool* create_thread_pool(int thread_count, int queue_size) {
    ThreadPool* pool = (ThreadPool*)malloc(sizeof(ThreadPool));
    pool->tasks = (Task*)malloc(sizeof(Task) * queue_size);
    pool->size = queue_size;
    pool->head = 0;
    pool->tail = 0;
    pool->count = 0;
    pthread_mutex_init(&pool->lock, NULL);
    pthread_cond_init(&pool->not_empty, NULL);
    pthread_cond_init(&pool->not_full, NULL);
    pool->shutdown = 0;
    pool->threads = (pthread_t*)malloc(sizeof(pthread_t) * thread_count);
    pool->thread_count = thread_count;
    for (int i = 0; i < thread_count; i++) {
        pthread_create(&pool->threads[i], NULL, worker, pool);
    }
    return pool;
}

// 銷毀線程池函數
void destroy_thread_pool(ThreadPool* pool) {
    pthread_mutex_lock(&pool->lock);
    pool->shutdown = 1;
    pthread_mutex_unlock(&pool->lock);
    pthread_cond_broadcast(&pool->not_empty);
    for (int i = 0; i < pool->thread_count; i++) {
        pthread_join(pool->threads[i], NULL);
    }
    free(pool->threads);
    free(pool->tasks);
    pthread_mutex_destroy(&pool->lock);
    pthread_cond_destroy(&pool->not_empty);
    pthread_cond_destroy(&pool->not_full);
    free(pool);
}

// 提交任務函數
void submit_task(ThreadPool* pool, void (*task)(void*), void* arg) {
    pthread_mutex_lock(&pool->lock);
    while (pool->count == pool->size && !pool->shutdown) {
        pthread_cond_wait(&pool->not_full, &pool->lock);
    }
    if (pool->shutdown) {
        pthread_mutex_unlock(&pool->lock);
        return;
    }
    pool->tasks[pool->tail].task = task;
    pool->tasks[pool->tail].arg = arg;
    pool->tail = (pool->tail + 1) % pool->size;
    pool->count++;
    pthread_cond_signal(&pool->not_empty);
    pthread_mutex_unlock(&pool->lock);
}

// 任務函數
void task_func(void* arg) {
    int* num = (int*)arg;
    printf("task %d is running\n", *num);
    free(num);
}

// 任務包裝函數
void* task_wrapper(void* arg) {
    TaskWrapper* wrapper = (TaskWrapper*)arg;
    submit_task(wrapper->pool, wrapper->task, wrapper->arg);
    free(wrapper);
    return NULL;
}

init_instance() {
	instance = (ThreadPoolSingleton*)malloc(sizeof(ThreadPoolSingleton));
	instance->pool = create_thread_pool(THREAD_POOL_SIZE, THREAD_POOL_SIZE);
}
// 獲取線程池單例對象函數
ThreadPool* get_thread_pool_instance() {
    return instance->pool;
}

int main() {
	init_instance();	/* 程序一開始,就必須執(zhí)行。不然,與懶漢式無較大差異 */
    ThreadPool* pool = get_thread_pool_instance(); // 獲取線程池單例對象
    for (int i = 0; i < 10; i++) {
        int* num = (int*)malloc(sizeof(int));
        *num = i;
        TaskWrapper* wrapper = (TaskWrapper*)malloc(sizeof(TaskWrapper));
        wrapper->pool = pool
		wrapper->task = task_func;
		wrapper->arg = num;
		pthread_t tid;
		pthread_create(&tid, NULL, task_wrapper, wrapper); // 提交任務
	}
	sleep(1); // 等待所有任務執(zhí)行完畢
	destroy_thread_pool(pool); // 銷毀線程池
	return 0;
}

/*
該示例代碼中,使用了單例模式來創(chuàng)建線程池對象,保證了整個程序中只有一個線程池對象。
線程池中包含了任務隊列、工作線程數組、互斥鎖、條件變量等成員,通過這些成員來實現任務的提交和執(zhí)行。
在主函數中,提交了10個任務,每個任務都是一個簡單的打印數字的函數,最后等待所有任務執(zhí)行完畢后銷毀線程池。
*/

到此這篇關于C++單例模式實現線程池的示例代碼的文章就介紹到這了,更多相關C++單例模式實現線程池內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • 用Visual Studio2017寫C++靜態(tài)庫圖文詳解

    用Visual Studio2017寫C++靜態(tài)庫圖文詳解

    這篇文章主要介紹了用Visual Studio2017寫C++靜態(tài)庫的圖文教程,需要的朋友可以參考下
    2017-04-04
  • OpenCV基于背景減除實現行人計數

    OpenCV基于背景減除實現行人計數

    本文主要介紹了如何使用OpenCV C++對視頻中的人流量進行統(tǒng)計。文中的示例代碼講解詳細,對我們學習OpenCV有一定的幫助,需要的可以了解一下
    2022-01-01
  • C++11中移動構造函數案例代碼

    C++11中移動構造函數案例代碼

    C++11 標準中為了滿足用戶使用左值初始化同類對象時也通過移動構造函數完成的需求,新引入了 std::move() 函數,它可以將左值強制轉換成對應的右值,由此便可以使用移動構造函數,對C++11移動構造函數相關知識感興趣的朋友一起看看吧
    2023-01-01
  • vs2019配置C++版OpenCV的方法步驟

    vs2019配置C++版OpenCV的方法步驟

    最近要用到很多OpenCV的庫,所以開始學了點OpenCV,本文記錄VS和OpenCV的安裝、配置過程。具有一定的參考價值,感興趣的可以了解一下
    2021-09-09
  • C/C++ 常用排序算法整理匯總分享

    C/C++ 常用排序算法整理匯總分享

    排序算法,就是如何使得記錄按照要求排列的方法。排序算法在很多領域得到相當地重視,尤其是在大量數據的處理方面。一個優(yōu)秀的算法可以節(jié)省大量的資源。本篇整理了c語言和c++的常用的排序算法,感興趣的朋友可以參考下
    2021-06-06
  • Android App仿微信界面切換時Tab圖標變色效果的制作方法

    Android App仿微信界面切換時Tab圖標變色效果的制作方法

    這篇文章主要介紹了Android App仿微信界面切換時Tab圖標變色效果的制作方法,重點講解了圖標的繪制技巧,需要的朋友可以參考下
    2016-04-04
  • C++中new和delete的使用方法詳解

    C++中new和delete的使用方法詳解

    這篇文章主要介紹了C++中new和delete的使用方法詳解的相關資料,希望通過本文能幫助到大家,需要的朋友可以參考下
    2017-10-10
  • C語言約瑟夫環(huán)的實現

    C語言約瑟夫環(huán)的實現

    這篇文章主要介紹了C語言約瑟夫環(huán)的實現的相關資料,這里主要是利用數據數據結果中循環(huán)鏈表來實現,需要的朋友可以參考下
    2017-08-08
  • C++中IO多路復用(select、poll、epoll)的實現

    C++中IO多路復用(select、poll、epoll)的實現

    I/O多路復用是一種并發(fā)處理多個I/O操作的機制,本文主要介紹了C++中IO多路復用(select、poll、epoll)的實現,具有一定的參考價值,感興趣的可以了解一下
    2024-03-03
  • 利用Matlab實現時域分析功能的示例詳解

    利用Matlab實現時域分析功能的示例詳解

    利用MATLAB可以方便地進行控制系統(tǒng)的時域分析。這篇文章主要通過簡單的示例為大家介紹了Matlab進行時域分析的具體操作,需要的可以參考一下
    2023-02-02

最新評論