深入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;

}

 

本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/future_fighter/archive/2009/02/16/3897183.aspx

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值