大家知道,在Linux下每个进程都有一个ID,叫做进程ID。而线程ID呢?
如果我们使用posix线程库pthread创建线程,那每个线程的ID是谁生成的呢?是这个库自己生成的,所以它保证在一个进程内的ID保持不重复。但不同的进程间就没有这个保障了。
其实,每个进程内的线程库生成的线程,应该算是用户态的线程,只有这些线程映射到操作系统内核所认识的线程,才能被调度。这个时候,映射到操作系统内核能识别的线程的时候,操作系统的对应线程也会有一个线程ID,这个ID在整个操作系统空间是唯一的。
通常这个操作系统的内部ID我们都用不到。所以大家也不关注。而在一个进程内的线程需要和另一个进程内的线程通信的时候(操作系统级别的进程间通信)才会用到,因为需要标识唯一的一个线程。
上述的三个ID的获取办法如下:
- getpid():获取进程ID
- pthread_self():获取线程库维护的线程ID
- syscall(SYS_gettid):由于标准库没有封装调用,需要进行系统调用获取内核的线程ID
另外,主线程(main)获取的进程ID==线程ID,而子线程就会不同。
void *subthread(void *s)
{
printf("%s(), line = %d, getpid() = %#x\n",__FUNCTION__,__LINE__,getpid());
printf("%s(), line = %d, pthread_self() = %#lx\t, SYS_gettid = %#lx\n",__FUNCTION__,__LINE__, pthread_self(), syscall(SYS_gettid));
return NULL;
}
int main()
{
printf("%s(), line = %d, getpid() = %#x\n",__FUNCTION__,__LINE__,getpid());
printf("%s(), line = %d, pthread_self() = %#lx\t, SYS_gettid = %#lx\n",__FUNCTION__,__LINE__, pthread_self(), syscall(SYS_gettid));
}
输出:
main(), line = 21, getpid() = 0x8692
main(), line = 22, pthread_self() = 0x7f9f12fbc740 , SYS_gettid = 0x8692
subthread(), line = 14, getpid() = 0x8692
subthread(), line = 15, pthread_self() = 0x7f9f12fbb640 , SYS_gettid = 0x8693
原文链接:https://blog.csdn.net/fruitful_life/article/details/125475793