大家知道,在Linux下每个进程都有一个ID,叫做进程ID。而线程ID呢?我们平时使用的posix线程库所创建的每个线程的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