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。
来看一个例子:
这里写图片描述
我们用while(1)来防止进程死掉
执行结果:
这里写图片描述

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

这里写图片描述

执行结果:
这里写图片描述

3 pthread_exit
函数原型:
void pthread_exit(void* retval);
参数代表返回给进程的值
这里写图片描述

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

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

pthread_exit的参数是返回的值

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

执行结果:
这里写图片描述

下面我们来看下创建多个线程:
这里写图片描述

执行结果:
这里写图片描述

我执行了多次,都发现是已经同步的了,不知道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 线程管理就总结到这里,如有问题,欢迎指正,谢谢。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值