Linux 线程管理

相信大家用java语言写线程已经很熟悉了,今天我们就来看下,在Linux下开发的时候怎么进行线程的管理
1 pthread_create函数
创建一个线程
函数原型:int pthread_create((pthread_t thread, pthread_attr_t *attr, void start_routine)(void ), void *arg)
第一个参数是线程标识符
第二个参数是线程的一些属性,我们一般设置为NULL即可
第三个参数是线程的执行方法
第四个参数是传入的值
返回值:成功,返回0;出错,返回-1。
来看一个例子:
Linux 线程管理_第1张图片
我们用while(1)来防止进程死掉
执行结果:
这里写图片描述

2 pthread_join函数
如果不想用while(1),可以用pthread_join来等待线程结束
函数原型:
int pthread_join(pthread_t thread, void **retval);
第一个参数是线程标示符
第二个参数用来存储被等待线程的返回值
返回值 : 0代表成功。 失败,返回的则是错误号

Linux 线程管理_第2张图片

执行结果:
Linux 线程管理_第3张图片

3 pthread_exit
函数原型:
void pthread_exit(void* retval);
参数代表返回给进程的值
Linux 线程管理_第4张图片

pthread_create的第三个参数是传入线程的值

执行函数thread_function的参数就是刚才传入线程的值

pthread_exit的参数是返回的值

pthread_join的第二个参数是最终获取到的返回的值

执行结果:
Linux 线程管理_第5张图片

下面我们来看下创建多个线程:
Linux 线程管理_第6张图片

执行结果:
Linux 线程管理_第7张图片

我执行了多次,都发现是已经同步的了,不知道Linux内核做了什么优化

如果我们想主动加上同步,可以通过互斥锁的方式
初始化锁。在Linux下,线程的互斥量数据类型是pthread_mutex_t。在使用前,要对它进行初始化。
静态分配:pthread_mutex_t mutex = PTHREAD_MUTEX_INITIALIZER

加锁。对共享资源的访问,要对互斥量进行加锁,如果互斥量已经上了锁,调用线程会阻塞,直到互斥量被解锁。
int pthread_mutex_lock(pthread_mutex *mutex);
解锁。在完成了对共享资源的访问后,要对互斥量进行解锁。
int pthread_mutex_unlock(pthread_mutex_t *mutex);

Linux 线程管理_第8张图片

执行结果:
Linux 线程管理_第9张图片

好了,Linux 线程管理就总结到这里,如有问题,欢迎指正,谢谢。

你可能感兴趣的:(linux)