本文主要是介绍posix thread小程序,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
posix thread在头文件pthread.h中,基本操作有:
(1)int pthread_create(pthread_t *thread, const pthread_attr_t *attr, void (*start)(void *), void *arg),创建一个线程(线程id,线程属性参数,线程调用的函数start,线程传递参数),成功返回0,失败返回error错误标志。可以由头文件errno.h中的strerror接收错误类型。
(2)void pthread_exit(void *retval)终止当前线程,成功返回0,失败返回error。retval线程结束或取消时返回的指针
(3)int pthread_join(pthread_t thread, void **thread_return)挂起当前线程,等待thread执行完后再执行。thread_return线程取消或者结束时返回的指针。
(4)pthread_t pthread_self(void)返回当前线程。
(5)int pthread_equal(pthread_t thread1, pthread_t thread2)判断两个线程是否相同,如果相同返回非零值,否则返回0。
(6)int pthread_detach(ptread_t thread)从进程中分离出资源来给该线程,当线程结束时收回。调用成功返回0,否则返回非零值。
线程的同步机制:互斥量(mutex),连接/合并(join),条件变量(condition vavriables)
互斥量mutex,通过mutex_lock_count判断当前互斥量是不是应经锁住。
(1)pthread_mutex_t mymutex;定义一个互斥量。静态初始化PTHREAD_MUTEX_INITIALIZER。动态初始化pthread_mutex_init()。静态初始化时头文件pthread.h中定义的一个宏。只能适用于定义是初始化。
(2)int pthread_mutex_lock(pthread_mutex_t *mymutex)加锁,mutex_lock_count++,成功返回0,失败返回错误标志,并阻塞当前线程等待mymutex可用时再执行。
(3)int pthread_mutex_trylock(pthread_mutex_t *mymutex)增加了一个try。
(4)int pthread_mutex_unlock(pthread_mutex_t *mymutex)解锁,mutex_lock_count--,释放资源。
/*
完成一个有趣的游戏(类似抢板凳):主线程中创建线程1,然后线程1再创建2个线程2,3,线程2,3分别为一个计数器,
操作counter(初值为0),线程2每使用一次加3,线程3每用一次加5,如果加到被15整除,那么counter加8,
看哪个线程先加到9999,并计算自己使用了多少次计算器。先到者胜利,并打印出相应信息。
*/
#include <iostream>
#include <pthread.h>
using namespace std;
#define MAXN 999999
struct node{int cnt;int key;
};
node res1, res2;
pthread_mutex_t mymutex = PTHREAD_MUTEX_INITIALIZER;
int counter;
void *add2(void *arg) {while( 1 ) {pthread_mutex_lock(&mymutex);if( counter < MAXN ) {counter += 5;if( counter%5 == 0 ) counter += 8;res2.cnt++;if( counter >= MAXN )res2.key = 1;cout << "add2 -> " << counter << endl;}else {pthread_mutex_unlock(&mymutex);break;}pthread_mutex_unlock(&mymutex);}
}
void *add1(void *arg) {while( 1 ) {pthread_mutex_lock(&mymutex);if( counter < MAXN ) {counter += 3;res1.cnt++;if( counter >= MAXN )res1.key = 1;cout << "add1 -> " << counter << endl; }else {pthread_mutex_unlock(&mymutex);break;}pthread_mutex_unlock(&mymutex);}
}
void *start(void *arg) {int status;pthread_t thread_2;status = pthread_create(&thread_2, NULL, add1, NULL);cout << "thread_2 " << status << endl;if( status ) {cout << "thread_2 error" << endl;return NULL;}pthread_t thread_3;status = pthread_create(&thread_3, NULL, add2, NULL);cout << "thread_3" << status << endl;if( status ) {cout << "thread3_error" << endl;return NULL; } pthread_join(thread_2, NULL);pthread_join(thread_3, NULL);return NULL;
}
int main()
{res1.cnt = res1.key = 0;res2.cnt = res2.key = 0;counter = 0;int status;pthread_t thread_1;status = pthread_create(&thread_1,NULL, start,NULL);cout << "main " << status << endl;if( !status ) {pthread_join(thread_1,NULL);cout << "res1: cnt=" << res1.cnt << ", key=" << res1.key << endl;cout << "res2: cnt=" << res2.cnt << ", key=" << res2.key << endl;}elsecout << "thread_1 error" << endl;return 0;
}
这篇关于posix thread小程序的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!