深入Pthread(四):一次初始化-pthread_once_t

深入Pthread(四):一次初始化-pthread_once_t

 

用到的API:

pthread_once_t once_control = PTHREAD_ONCE_INIT;
int pthread_once(pthread_once_t* once_control, void (*init_routine)(void));
    
    有些事需要一次且仅需要一次执行。通常当初始化应用程序时,可以比较容易地将其放在main函数中。但当你写一个库时,就不能在main里面初始化了,你可以用静态初始化,但使用一次初始化(pthread_once_t)会比较容易些。
 

例程:

#include <pthread.h>
#include "errors.h"
 
 
pthread_once_t once_block = PTHREAD_ONCE_INIT;
pthread_mutex_t mutex;
 
 
/*This is the one-time initialization routine. It will be
* called exactly once, no matter how many calls to pthread_once
* with the same control structure are made during the course of
* the program.
*/
 
void once init routine (void)
{

    int status;

    status = pthread_mutex_init (&mutex, NULL);

    if (status != 0)

        err_abort (status, "Init Mutex");

}
 
/* Thread start routine that calls pthread_once. 
*/
void *thread routine (void *arg) 
{
    int status; 
    status = pthread_once (&once_block, once_init_routine); 
    if (status != 0) 
        err_abort (status, "Once init"); 
    status = pthread_mutex_lock (&mutex); 
    if (status != 0) 
        err_abort (status, "Lock mutex"); 
    printf ("thread routine has locked the mutex./n");
 
    status = pthread_mutex_unlock (&mutex); 
    if (status ! = 0) 
        err_abort (status, "Unlock mutex"); 
    return NULL; 
}
 
int main (int argc, char *argv[]) 
{
    pthread_t thread_id; 
    char *input, buffer[64]; 
    int status; 
    status = pthread_create (&thread_id, NULL, thread_routine, NULL); 
    if (status != 0) 
        err_abort (status, "Create thread"); 
    status = pthread_once (&once_block, once_init_routine); 
    if (status != 0) 
        err_abort (status, "Once init"); 
    status = pthread_mutex_lock (&mutex); 
    if (status != 0) 
        err_abort (status, "Lock mutex"); 
    printf ("Main has locked the mutex./n"); 
    status = pthread_mutex_unlock (&mutex); 
    if (status != 0) 
        err_abort (status, "Unlock mutex"); 
    status = pthread_join (thread_id, NULL); 
    if (status != 0) 
        err_abort (status, "Join thread"); 
    return 0; 
}
 
 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值