用互斥线程进行同步
2012-07-01 19:29
295 查看
#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;
#define MSIZE 1024
char work_area[MSIZE];
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 init failed!\n");
exit(EXIT_FAILURE);
}
res=pthread_create(&a_thread,NULL,thread_function,NULL);
if(res!=0)
{
perror("Thread creation failed!\n");
exit(EXIT_FAILURE);
}
pthread_mutex_lock(&work_mutex);
printf("Input some text.Enter 'end' to finish\n");
while(!time_to_exit)
{
fgets(work_area,MSIZE,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!\n");
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("Ypu input %d num\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);
}
#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;
#define MSIZE 1024
char work_area[MSIZE];
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 init failed!\n");
exit(EXIT_FAILURE);
}
res=pthread_create(&a_thread,NULL,thread_function,NULL);
if(res!=0)
{
perror("Thread creation failed!\n");
exit(EXIT_FAILURE);
}
pthread_mutex_lock(&work_mutex);
printf("Input some text.Enter 'end' to finish\n");
while(!time_to_exit)
{
fgets(work_area,MSIZE,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!\n");
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("Ypu input %d num\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);
}
相关文章推荐
- 为了在线程间进行可靠的通信,也为了互斥访问,同步是必要的。
- 线程的同步与互斥
- 线程之间的互斥和同步
- 两线程间无锁进行数据同步
- Windows线程的同步与互斥
- 经典生产者与消费者问题(线程的同步与互斥)
- BCB线程的互斥与同步
- Windows编程-- 线程和内核对象的同步 - 互斥对象内核对象
- Linux 进程与线程的同步与互斥
- 线程的同步与互斥(死锁的产生和避免)
- 线程的同步与互斥:条件变量&信号量
- Linux — 浅析线程以及多线程的同步与互斥
- Linux下的多线程编程二(线程的同步与互斥)
- Linux环境下线程的同步与互斥以及死锁问题
- <linux线程>同步互斥机制之【条件变量】
- 操作系统 进程/线程 同步与互斥
- Java并发原语——线程、互斥与同步
- 线程(进程)的同步与互斥实例
- 对制造者线程和使用者线程进行同步(C# 编程指南)
- MFC_互斥对象_打印字符串_2线程_同步