pthread_once

pthread_once从APUE的角度来看,来源于线程的私有数据。线程的私有数据需要使用一个pthread_key_create()创建一个pthread_key_t键值,这个键值需要被进程中的所有线程使用。pthread_key_create()函数一般写在线程函数中,而且需要确保这个函数只被执行一次,为防止不同的线程竞争调用pthread_key_create()函数从而导致不同的线程访问到不同的pthread_key_t键值,提出了pthread_once。pthread_once能够保证initfn只被调用一次,所以可以将initfn换为pthread_key_create()。

#include <pthread.h>
pthread_once_t initflag = PTHREAD_ONCE_INIT;
int pthread_once(pthread_once_t *initflag, void (*initfn)(void));
initflag必须是一个非本地变量。

pthread_once在被一个线程A调用时,如果另一个线程B也要调用pthread_once,那么该线程B就会等待线程A调用完pthread_once。下面是一段程序说明这个问题:

#include <pthread.h>
#include <stdio.h>
#include <unistd.h>
pthread_once_t once=PTHREAD_ONCE_INIT;
pthread_mutex_t mutex;

void once_init_routine(void)
{
    int status;
    status = pthread_mutex_init(&mutex,NULL);
    if(status == 0)
        printf("Init success!,My id is %u\n", pthread_self());
}

void *child_thread(void *arg)
{
    printf("I'm child, My id is %u\n",pthread_self());
    pthread_once(&once,once_init_routine);
}

int main(int argc,char *argv[])
{
    pthread_t child_thread_id;
    pthread_create(&child_thread_id,NULL,child_thread,NULL);
    printf("I'm father, my id is %u\n",pthread_self());
    pthread_once(&once,once_init_routine);
    printf("wait for the child pthread_once\n");
}
结果如下:

I'm father, my id is 3488159552
I'm child, My id is 3471374080
Init success!,My id is 3488159552
wait for the child pthread_once





  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值