linux程序设计笔记--pthread--mutex

本文通过实例探讨了并发编程中互斥量的使用,包括初始化、加锁、解锁和销毁过程,以及如何在多线程环境中保护共享资源。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 互斥量:
 #include<pthread.h>
 int pthread_mutex_init(pthread_mutex_t*mutex,const pthread_mutexattr_t *mutex_attr);
 intpthread_mutex_lock(pthread_mutex_t *mutex);
 intpthread_mutex_unlock(pthread_mutex_t *mutex);
 intpthread_mutex_destroy(pthread_mutex_t *mutex);

例程:

#include <stdio.h>

#include <unistd.h>

#include <stdlib.h>

#include <string.h>

#include <pthread.h>

#include <semaphore.h>



void *thread_function(void *arg);

pthread_mutex_t work_mutex; /* protects both work_area andtime_to_exit */



#define WORK_SIZE 1024

char work_area[WORK_SIZE];

int time_to_exit = 0;



int main() {

     int res;

    pthread_t a_thread;

    void *thread_result;

    res = pthread_mutex_init(&work_mutex, NULL);

    if (res != 0) {

        perror("Mutex initialization failed");

        exit(EXIT_FAILURE);

    }

    res = pthread_create(&a_thread, NULL, thread_function,NULL);

    if (res != 0) {

        perror("Thread creation failed");

        exit(EXIT_FAILURE);

    }

    pthread_mutex_lock(&work_mutex);

    printf("Input some text. Enter 'end' to finish\n");

    while(!time_to_exit) {

        fgets(work_area, WORK_SIZE, stdin);

        pthread_mutex_unlock(&work_mutex);

        while(1) {

            pthread_mutex_lock(&work_mutex);

            if (work_area[0] != '\0') {

                pthread_mutex_unlock(&work_mutex);

                sleep(1);

            } else {

                break;

            }

        }

    }

    pthread_mutex_unlock(&work_mutex);

    printf("\nWaiting for thread to finish...\n");

    res = pthread_join(a_thread, &thread_result);

    if (res != 0) {

        perror("Thread join failed");

        exit(EXIT_FAILURE);

    }

    printf("Thread joined\n");

    pthread_mutex_destroy(&work_mutex);

    exit(EXIT_SUCCESS);

}



void *thread_function(void *arg) {

    sleep(1);

    pthread_mutex_lock(&work_mutex);

    while(strncmp("end", work_area, 3) != 0) {

        printf("You input %d characters\n",strlen(work_area) -1);

        work_area[0] = '\0';

        pthread_mutex_unlock(&work_mutex);

        sleep(1);

        pthread_mutex_lock(&work_mutex);

        while (work_area[0] == '\0' ) {

            pthread_mutex_unlock(&work_mutex);

            sleep(1);

            pthread_mutex_lock(&work_mutex);

        }

    }

    time_to_exit = 1;

    work_area[0] = '\0';

    pthread_mutex_unlock(&work_mutex);

    pthread_exit(0);

}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值