Linux下多线程同步方式之互斥量,信号量,条件变量
生活随笔
收集整理的這篇文章主要介紹了
Linux下多线程同步方式之互斥量,信号量,条件变量
小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
// linux_thread_syn.cpp : 定義控制臺(tái)應(yīng)用程序的入口點(diǎn)。
//#include "stdafx.h"//互斥量
#include <cstdio>
#include <cstdlib>
#include <unistd.h>
#include <pthread.h>
#include "iostream"
using namespace std;
pthread_mutex_t mutex = PTHREAD_MUTEX_INITIALIZER;
int tmp;
void* thread(void *arg)
{ cout << "thread id is " << pthread_self() << endl; pthread_mutex_lock(&mutex); tmp = 12; cout << "Now a is " << tmp << endl; pthread_mutex_unlock(&mutex); return NULL;
}
int main()
{ pthread_t id; cout << "main thread id is " << pthread_self() << endl; tmp = 3; cout << "In main func tmp = " << tmp << endl; if (!pthread_create(&id, NULL, thread, NULL)) { cout << "Create thread success!" << endl; } else { cout << "Create thread failed!" << endl; } pthread_join(id, NULL); pthread_mutex_destroy(&mutex); return 0;
}
//編譯:g++ -o thread testthread.cpp -lpthread //條件變量
#include <stdio.h>
#include <pthread.h>
#include "stdlib.h"
#include "unistd.h"
pthread_mutex_t mutex;
pthread_cond_t cond;
void hander(void *arg)
{ free(arg); (void)pthread_mutex_unlock(&mutex);
}
void *thread1(void *arg)
{ pthread_cleanup_push(hander, &mutex); while(1) { printf("thread1 is running\n"); pthread_mutex_lock(&mutex); pthread_cond_wait(&cond, &mutex); printf("thread1 applied the condition\n"); pthread_mutex_unlock(&mutex); sleep(4); } pthread_cleanup_pop(0);
}
void *thread2(void *arg)
{ while(1) { printf("thread2 is running\n"); pthread_mutex_lock(&mutex); pthread_cond_wait(&cond, &mutex); printf("thread2 applied the condition\n"); pthread_mutex_unlock(&mutex); sleep(1); }
}
int main()
{ pthread_t thid1,thid2; printf("condition variable study!\n"); pthread_mutex_init(&mutex, NULL); pthread_cond_init(&cond, NULL); pthread_create(&thid1, NULL, thread1, NULL); pthread_create(&thid2, NULL, thread2, NULL); sleep(1); do { pthread_cond_signal(&cond); }while(1); sleep(20); pthread_exit(0); return 0;
} #include <pthread.h>
#include <unistd.h>
#include "stdio.h"
#include "stdlib.h"
static pthread_mutex_t mtx = PTHREAD_MUTEX_INITIALIZER;
static pthread_cond_t cond = PTHREAD_COND_INITIALIZER;
struct node
{ int n_number; struct node *n_next;
}*head = NULL; static void cleanup_handler(void *arg)
{ printf("Cleanup handler of second thread./n"); free(arg); (void)pthread_mutex_unlock(&mtx);
}
static void *thread_func(void *arg)
{ struct node *p = NULL; pthread_cleanup_push(cleanup_handler, p); while (1) { //這個(gè)mutex主要是用來保證pthread_cond_wait的并發(fā)性 pthread_mutex_lock(&mtx); while (head == NULL) { //這個(gè)while要特別說明一下,單個(gè)pthread_cond_wait功能很完善,為何 //這里要有一個(gè)while (head == NULL)呢?因?yàn)閜thread_cond_wait里的線 //程可能會(huì)被意外喚醒,如果這個(gè)時(shí)候head != NULL,則不是我們想要的情況。 //這個(gè)時(shí)候,應(yīng)該讓線程繼續(xù)進(jìn)入pthread_cond_wait // pthread_cond_wait會(huì)先解除之前的pthread_mutex_lock鎖定的mtx, //然后阻塞在等待對(duì)列里休眠,直到再次被喚醒(大多數(shù)情況下是等待的條件成立 //而被喚醒,喚醒后,該進(jìn)程會(huì)先鎖定先pthread_mutex_lock(&mtx);,再讀取資源 //用這個(gè)流程是比較清楚的 pthread_cond_wait(&cond, &mtx); p = head; head = head->n_next; printf("Got %d from front of queue/n", p->n_number); free(p); } pthread_mutex_unlock(&mtx); //臨界區(qū)數(shù)據(jù)操作完畢,釋放互斥鎖 } pthread_cleanup_pop(0); return 0;
}
int main(void)
{ pthread_t tid; int i; struct node *p; //子線程會(huì)一直等待資源,類似生產(chǎn)者和消費(fèi)者,但是這里的消費(fèi)者可以是多個(gè)消費(fèi)者,而 //不僅僅支持普通的單個(gè)消費(fèi)者,這個(gè)模型雖然簡單,但是很強(qiáng)大 pthread_create(&tid, NULL, thread_func, NULL); sleep(1); for (i = 0; i < 10; i++) { p = (struct node*)malloc(sizeof(struct node)); p->n_number = i; pthread_mutex_lock(&mtx); //需要操作head這個(gè)臨界資源,先加鎖, p->n_next = head; head = p; pthread_cond_signal(&cond); pthread_mutex_unlock(&mtx); //解鎖 sleep(1); } printf("thread 1 wanna end the line.So cancel thread 2./n"); //關(guān)于pthread_cancel,有一點(diǎn)額外的說明,它是從外部終止子線程,子線程會(huì)在最近的取消點(diǎn),退出 //線程,而在我們的代碼里,最近的取消點(diǎn)肯定就是pthread_cond_wait()了。 pthread_cancel(tid); pthread_join(tid, NULL); printf("All done -- exiting/n"); return 0;
} //信號(hào)量
#include <stdlib.h>
#include <stdio.h>
#include <unistd.h>
#include <pthread.h>
#include <semaphore.h>
#include <errno.h>
#define return_if_fail(p) if((p) == 0){printf ("[%s]:func error!/n", __func__);return;}
typedef struct _PrivInfo
{ sem_t s1; sem_t s2; time_t end_time;
}PrivInfo; static void info_init (PrivInfo* thiz);
static void info_destroy (PrivInfo* thiz);
static void* pthread_func_1 (PrivInfo* thiz);
static void* pthread_func_2 (PrivInfo* thiz); int main (int argc, char** argv)
{ pthread_t pt_1 = 0; pthread_t pt_2 = 0; int ret = 0; PrivInfo* thiz = NULL; thiz = (PrivInfo* )malloc (sizeof (PrivInfo)); if (thiz == NULL) { printf ("[%s]: Failed to malloc priv./n"); return -1; } info_init (thiz); ret = pthread_create (&pt_1, NULL, (void*)pthread_func_1, thiz); if (ret != 0) { perror ("pthread_1_create:"); } ret = pthread_create (&pt_2, NULL, (void*)pthread_func_2, thiz); if (ret != 0) { perror ("pthread_2_create:"); } pthread_join (pt_1, NULL); pthread_join (pt_2, NULL); info_destroy (thiz); return 0;
}
static void info_init (PrivInfo* thiz)
{ return_if_fail (thiz != NULL); thiz->end_time = time(NULL) + 10; sem_init (&thiz->s1, 0, 1); sem_init (&thiz->s2, 0, 0); return;
}
static void info_destroy (PrivInfo* thiz)
{ return_if_fail (thiz != NULL); sem_destroy (&thiz->s1); sem_destroy (&thiz->s2); free (thiz); thiz = NULL; return;
}
static void* pthread_func_1 (PrivInfo* thiz)
{ return_if_fail(thiz != NULL); while (time(NULL) < thiz->end_time) { sem_wait (&thiz->s2); printf ("pthread1: pthread1 get the lock./n"); sem_post (&thiz->s1); printf ("pthread1: pthread1 unlock/n"); sleep (1); } return;
}
static void* pthread_func_2 (PrivInfo* thiz)
{ return_if_fail (thiz != NULL); while (time (NULL) < thiz->end_time) { sem_wait (&thiz->s1); printf ("pthread2: pthread2 get the unlock./n"); sem_post (&thiz->s2); printf ("pthread2: pthread2 unlock./n"); sleep (1); } return;
}
總結(jié)
以上是生活随笔為你收集整理的Linux下多线程同步方式之互斥量,信号量,条件变量的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: win32下多线程同步方式之临界区,互斥
- 下一篇: 网络编程五种IO模型之epoll模型