legongju.com
我们一直在努力
2025-01-16 08:07 | 星期四

pthread是否支持任务队列

pthread(POSIX Threads)本身并不直接支持任务队列

以下是一个简单的C语言示例,展示了如何使用pthread和队列实现一个简单的线程池:

#include
#include 
#include 
#include 

#define QUEUE_SIZE 10
#define NUM_THREADS 4

typedef struct Task {
    void (*func)(void *);
    void *arg;
} Task;

typedef struct TaskQueue {
    Task queue[QUEUE_SIZE];
    atomic_int head;
    atomic_int tail;
    pthread_mutex_t lock;
    pthread_cond_t cond;
} TaskQueue;

typedef struct ThreadPool {
    pthread_t threads[NUM_THREADS];
    TaskQueue task_queue;
} ThreadPool;

void task_queue_init(TaskQueue *task_queue) {
    task_queue->head = ATOMIC_VAR_INIT(0);
    task_queue->tail = ATOMIC_VAR_INIT(0);
    pthread_mutex_init(&task_queue->lock, NULL);
    pthread_cond_init(&task_queue->cond, NULL);
}

void task_queue_push(TaskQueue *task_queue, Task task) {
    pthread_mutex_lock(&task_queue->lock);
    while ((task_queue->tail + 1) % QUEUE_SIZE == task_queue->head) {
        pthread_cond_wait(&task_queue->cond, &task_queue->lock);
    }
    task_queue->queue[task_queue->tail] = task;
    task_queue->tail = (task_queue->tail + 1) % QUEUE_SIZE;
    pthread_cond_signal(&task_queue->cond);
    pthread_mutex_unlock(&task_queue->lock);
}

Task task_queue_pop(TaskQueue *task_queue) {
    pthread_mutex_lock(&task_queue->lock);
    while (task_queue->tail == task_queue->head) {
        pthread_cond_wait(&task_queue->cond, &task_queue->lock);
    }
    Task task = task_queue->queue[task_queue->head];
    task_queue->head = (task_queue->head + 1) % QUEUE_SIZE;
    pthread_cond_signal(&task_queue->cond);
    pthread_mutex_unlock(&task_queue->lock);
    return task;
}

void *thread_pool_worker(void *arg) {
    ThreadPool *thread_pool = (ThreadPool *)arg;
    while (1) {
        Task task = task_queue_pop(&thread_pool->task_queue);
        task.func(task.arg);
    }
    return NULL;
}

void thread_pool_init(ThreadPool *thread_pool) {
    task_queue_init(&thread_pool->task_queue);
    for (int i = 0; i < NUM_THREADS; i++) {
        pthread_create(&thread_pool->threads[i], NULL, thread_pool_worker, thread_pool);
    }
}

void thread_pool_add_task(ThreadPool *thread_pool, void (*func)(void *), void *arg) {
    Task task = {.func = func, .arg = arg};
    task_queue_push(&thread_pool->task_queue, task);
}

int main() {
    ThreadPool thread_pool;
    thread_pool_init(&thread_pool);

    // 添加任务到线程池
    for (int i = 0; i < 20; i++) {
        thread_pool_add_task(&thread_pool, my_function, (void *)(intptr_t)i);
    }

    // 等待所有任务完成
    // ...

    return 0;
}

这个示例中,我们创建了一个线程池,其中包含一个任务队列和四个工作线程。我们可以向线程池添加任务,这些任务将被工作线程从队列中取出并执行。注意,这个示例仅用于演示目的,实际应用中可能需要考虑更多细节,例如关闭线程池、处理错误等。

未经允许不得转载 » 本文链接:https://www.legongju.com/article/109804.html

相关推荐

  • pthread与其他多线程方式的比较

    pthread与其他多线程方式的比较

    pthread(POSIX Threads)是一种广泛使用的多线程编程库,它提供了一套用于创建、管理和同步线程的API。与其他多线程方式相比,pthread具有以下优势和特点:

  • 如何测试pthread的性能

    如何测试pthread的性能

    要测试 pthread(POSIX 线程)的性能,您可以创建一个简单的多线程程序并比较不同场景下的性能指标 创建一个简单的多线程程序:编写一个程序,该程序创建多个线程...

  • pthread的官方文档在哪里可以找到

    pthread的官方文档在哪里可以找到

    pthread的官方文档可以在多个地方找到,包括在线资源、特定系统的手册页以及源代码库。以下是一些主要的资源: 在线资源:POSIX Threads (pthreads) 的官方文档可...

  • 如何优化pthread的内存占用

    如何优化pthread的内存占用

    优化 pthread 的内存占用可以通过以下方法来实现: 减少线程数量:尽量避免创建过多的线程,因为每个线程都会占用一定的内存空间。可以考虑使用线程池来管理线程...

  • 在Android游戏中如何使用pthread

    在Android游戏中如何使用pthread

    在 Android 游戏中,可以使用 pthread 库来创建和管理线程 首先,确保你的项目已经包含了 pthread 库。通常情况下,Android NDK 会自动包含这个库。如果没有,请...

  • pthread的官方文档在哪里可以找到

    pthread的官方文档在哪里可以找到

    pthread的官方文档可以在多个地方找到,包括在线资源、特定系统的手册页以及源代码库。以下是一些主要的资源: 在线资源:POSIX Threads (pthreads) 的官方文档可...

  • 如何优化pthread的内存占用

    如何优化pthread的内存占用

    优化 pthread 的内存占用可以通过以下方法来实现: 减少线程数量:尽量避免创建过多的线程,因为每个线程都会占用一定的内存空间。可以考虑使用线程池来管理线程...

  • 在Android中使用pthread有哪些最佳实践

    在Android中使用pthread有哪些最佳实践

    在Android中使用pthread(POSIX线程库)时,可以遵循以下最佳实践: 使用线程池:避免频繁创建和销毁线程,这会导致性能下降。可以使用线程池来管理和复用线程,...