标签:
#include <pthread.c> int pthread_mutex_init(pthread_mutex_t *mutex, const pthread_mutexattr_t *mutexattr); int pthread_mutex_lock(pthread_mutex_t *mutex); int pthread_mutex_unlock(pthread_mutex_t *mutex); int pthread_mutex_destroy(pthread_mutex_t *mutex);与信号量相似,这些函数的参数都是一个先前声明过的对象的指针.对互斥量来说,这个对象的类型为pthread_mutex_t.pthread_mutex_init函数中的属性参数默认为fast,一般传递参数NULL保持默认属性.
/*************************************************************************
> File Name: thread4.c
> Description: thread4.c通过互斥量来保证任一时刻只有一个线程访问字符数组work_area(对它进行读(统计)/写)
> Author: Liubingbing
> Created Time: 2015年07月05日 星期日 20时47分06秒
> Other: thread4.c省略了对互斥量加锁和解锁调用的返回值应该进行的一些错误检查
************************************************************************/
#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_acea and time_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;
/* pthread_mutex_init初始化互斥量work_mutex */
res = pthread_mutex_init(&work_mutex, NULL);
if (res != 0) {
perror("Mutex initialization failed");
exit(EXIT_FAILURE);
}
/* pthread_create创建新线程
* a_thread中保存新线程的标识符, thread_function为新线程启动调用的函数 */
res = pthread_create(&a_thread, NULL, thread_function, NULL);
if (res != 0) {
perror("Thread creation failed");
exit(EXIT_FAILURE);
}
/* pthread_mutex_lock对互斥量work_mutex加锁,如果它已经被锁住,则这个调用将被阻塞直到它被释放为止 */
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_mutext解锁 */
pthread_mutex_unlock(&work_mutex);
while (1) {
/* pthread_mutex_lock对互斥量work_mutex加锁 */
pthread_mutex_lock(&work_mutex);
/* 如果work_area第一个字符不为null,则对互斥量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);
/* 首先试图对互斥量work_mutex加锁,如果它已经被锁住,这个调用将被阻塞直到它释放为止. */
pthread_mutex_lock(&work_mutex);
while (strncmp("end", work_area, 3) != 0) {
printf("You input %d characters\n", strlen(work_area) - 1);
/* 通过将第一个字符设置为null的方法来通知读取输入的线程, 新线程完成了字符统计 */
work_area[0] = '\0';
/* 对互斥量work_mutex解锁, 并等待主线程继续运行*/
pthread_mutex_unlock(&work_mutex);
sleep(1);
/* 对互斥量work_mutex加锁, 如果加锁成功就检查是否主线程又有字符送来要处理 */
pthread_mutex_lock(&work_mutex);
while (work_area[0] == '\0') {
/* 如果没有字符要处理,就解锁互斥量,继续等待 */
pthread_mutex_unlock(&work_mutex);
sleep(1);
pthread_mutex_lock(&work_mutex);
}
}
/* 如果work_area="end",则设置time_to_exit = 1, 之后退出 */
time_to_exit = 1;
work_area[0] = '\0';
pthread_mutex_unlock(&work_mutex);
pthread_exit(0);
}新线程首先对等待1秒,然后对互斥量work_mutex加锁,如果work_mutex已经加锁,则这个调用将被阻塞直到互斥量被时释放为止.一旦获得访问权,先判断work_area是否为end.版权声明:本文为博主原创文章,未经博主允许不得转载。
标签:
原文地址:http://blog.csdn.net/yiranant/article/details/46772403