linux线程同步

/* Copyright (c) 2014
 * All rights reserved
 * http://blog.csdn.net/ezhou_liukai
 */

#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <pthread.h>
#include <semaphore.h>

//using mutex lock to test thread synchronize
pthread_mutex_t g_mutex; 
  
void *mutex_lock_thread(void *agr)
{
    pthread_mutex_lock(&g_mutex);
    printf("\nthread_Id:%u start\n", (unsigned int) pthread_self());
    printf("susspend thread 0.2 s\n");
    sleep(0.2);
    printf("thread_Id:%u end\n", (unsigned int) pthread_self());
    pthread_mutex_unlock(&g_mutex); 
   
    return NULL;
}

void mutex_lock_test()
{
    printf("\n----------- mutex lock test ------------\n ");
    int i = 0, n = 10;
    pthread_t tid[10];
    
    pthread_setconcurrency(11);
    pthread_mutex_init(&g_mutex, NULL);
    for(i = 0; i < n; i++)
    {
        pthread_create(&tid[i], NULL, &mutex_lock_thread, NULL);
    }
   
    for(i = 0; i < n; i++)
    {
        pthread_join(tid[i], NULL);
    }
    
    printf("\n------------ mutex lock test end -----------\n");
}
//end using mutex lock to test thread synchronize


//using semaphore to test thread synchronize
sem_t g_sem;
void *semaphore_thread(void *agr)
{
    sem_wait(&g_sem);
    printf("\nthread_Id:%u start\n", (unsigned int) pthread_self());
    printf("suspend thread 0.2s\n");
    sleep(0.2);
    printf("thread_Is:%u end\n", (unsigned int) pthread_self());
    sem_post(&g_sem);

    return NULL;
}

void semaphore_test()
{
    printf("\n----------- semaphore test -----------\n");
    int i = 0, n = 10;
    pthread_t tid[10];
    sem_init(&g_sem, 0, 1);
    
    pthread_setconcurrency(11);
    for (i = 0; i < n; i++)
    {
        pthread_create(&tid[i], NULL, &semaphore_thread, NULL);
    }

    for (i = 0; i < n; i++)
    {
        pthread_join(tid[i], NULL);
    }
    printf("\n----------- semaphore test end -----------\n");
}
// end using semaphore to test thread synchronize


int main(int argc, char *argv[])
{ 
    mutex_lock_test();
    semaphore_test();    
    return 1;
}


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值