首先来看在Linux中如何实现多线程的,下面是《Linux内核设计与实现第三版》中扫描页的截图:
这段话我冒昧的解析一下,如有不当,欢迎指出,大家共同进步!
在Linux中线程和进程没有任何区别(站在内核角度来看),每个线程属于自己的task_struct,task_struct相当于在进程中的PCB(进程描述符),每创建一个新的进程就有一个新的进程描述符,在内核中线程看起来就是普通的进程,但是这个进程和它的主线程(在内核看来就是主进程)共享一块内存地址,同一个进程描述符!
下面来看一段代码来证明这个些个理论
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <pthread.h>
#include <string.h>
void* fun(void* arg)
{
for(int i = 0 ; i < 20 ; i++)
{
printf("pid = %d \n",getpid()); //创建两个子线程来打印当前的进程id
sleep(2);
}
pthread_exit(NULL);
}
int main()
{
pthread_t id[2];
for(int i = 0 ; i < 2 ; i++)
{
pthread_create(&id[i],NULL,fun,NULL);
}
for(int i = 0 ; i < 2 ; i++)
{
pthread_join(id[i],NULL);
}
}
然后上面代码的主要作用就是主线程创建两个子线程,来打印当前的进程id下面我来看运行结果:
可以看出来两子线程打印的id一毛一样,并且ps -eLf | grep 查看进程的时候,发现子线程打印出来的id就是主线程(主进程)的进程id,且有三个进程,这样也印证了我们开头说的那些话,在Linux内核看来,进程和线程没区别,只不过线程共享部分资源,例如内存,线程描述符等东西!