本篇文章主要围绕线程控制来进行展开。
主题思路是以create与join两个接口展开。
目录
- pthread_create 与 pthread_join:
- pthread_create:
- pthread_join:
- 代码:
- 问题一:主线程与新线程谁先退出?
- 问题二:哪个线程应该最后退出?
- 问题三:tid是什么样子的?
- 问题四:怎么更好的理解新线程函数的传参?
pthread_create 与 pthread_join:
现在只是粗略的了解一下create与join这个函数的参数与返回值:
pthread_create:
这是进行线程创建的函数
参数一:
他是一个输出型参数,为线程的id,这是库提供的类型,本是一个无符号长整型。
参数二:
这个是关于线程属性的,不会用到,我们写为nullptr即可。
参数三:
是一个函数指针,是我们新线程要去执行的函数。
参数四:
传参给参数三中的函数。
关于返回值,带有pthread前缀的函数返回值都是统一的:
成功时返回0,失败时返回错误码。
pthread_join:
我们的进程需要等待,线程当然也需要进行等待,join就是。
参数一:
将指定tid传给他即可。
参数二:
这是接收新线程执行函数的返回值,我们暂时不关心,先设置为nuliptr。
随后会围绕这两个函数进行展开,细节都会涉及到。
代码:
进程控制本质上就是一堆的函数调用,我们当然是要结合代码来看。
问题一:主线程与新线程谁先退出?
我们先写一段最简单的代码:
观察现象:
那么这里后出现一个问题,也就是我们的问题一。
所以应该谁先运行,答案是不确定的,
因为它取决于OS的调度策略与运气等因素,好吧…
问题二:哪个线程应该最后退出?
与我们的进程一样,进程需要父进程来进行等待,所以父进程应最后退出;
线程也应该是主线程最后退出,进行对应的等待。
那么怎么保证他可以最后退出?答案就是join会进行阻塞等待。
如果主线程不进行join?
当主线程退了,那么整个进程就相当于退出了。我们不推荐这种做法,这样的行为是没有意义的。
当主线程没退,新线程跑完,会出现类似僵尸进程的概念。
对于join可以进行等待我们可以验证一下:
对threadRun进行修改一下即可。
利用命令:while ;: do ps -aL ; sleep 1; done
进行观察,果然过了5s后都退出了。
问题三:tid是什么样子的?
我们已经说过他的本质是一个无符号数字,我们来看看:
他是什么样子。
打印出来是个很大的数字?
为什么和我们的LWP不一样?
tid实际上是一个虚拟地址,更具体一些的需要等等再说。
问题四:怎么更好的理解新线程函数的传参?
我们已经实验过使用对于传参我们可以传一个字符串,进行强转就可以使用,那么我们可以穿内置类型指针,甚至自定义类型指针?
我们一步一步来看,先来看内置类型的。
我们先在栈中定义一个变量a,将他的地址强转为void*传给函数。
现象:果然循环5次打印10。
那么自定义类型?
代码:
对于ThreadRun函数修改一下打印即可。
现象:
这就意味着我们可以给线程传递多个参数甚至是方法。
但是我们这样写的代码还有一个问题,因为