Реализация рабочих потоков (в Linux): Насколько это оскорбительно? - PullRequest
0 голосов
/ 21 апреля 2009
#include <pthread.h>
static void * worker_thread(void *);

void some_func(void)
{
    pthread_t * tmp;
    tmp = malloc(sizeof(pthread_t));
    if (NULL != tmp)
    {
        if (!pthread_create(tmp, NULL, worker_thread, (void *)tmp))
            pthread_detach(*tmp);
        else
            free(tmp);
    }
}

static void * worker_thread(void * p)
{
    /* do work */
    free(p);
    return(NULL);
}

1 Ответ

2 голосов
/ 15 мая 2009

Из комментариев я узнал, что структура pthread_t не обязана быть «живой» в течение всего потока (что я и думал и почему я использовал malloc); переменная стека в порядке. То, что я закончил, было основано на комментарии Джейсона Коко:

#include <pthread.h>

static void * worker_thread(void *);

void start_worker(void * arg)
{
    pthread_t tmp;
    (void)pthread_create(& tmp, NULL, worker_thread, arg))
}

static void * worker_thread(void * p)
{
    /* do work */

    /* finished work */
    pthread_detach(pthread_self());
    return (p);
}
...