进程和线程ID

        大家知道,在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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值