如何获取进程的线程id?------说说gettid与pthread_self的区别

2024-02-06 10:48

本文主要是介绍如何获取进程的线程id?------说说gettid与pthread_self的区别,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

       一切源于需求,需要用到,所以来说说。

 

       之前一直用pthread_self来获取线程id, 这个id通常臭大臭大的。让我纳闷的是,翻遍了所有资料,没有办法通过linux命令来获取线程id, 我不信这个邪。

       当然, 我也查到了, 可以用 ps -Tp pid或者top -Hp pid的方式来获取线程id,  我用了这两个命令,但获取不到如上的线程id. 后来我才明白, 这两个命令确实可以获取到线程id,  但不是上述那个臭大臭大的id, 其实, 这就涉及到gettid与pthread_self的区别了。

       gettid获取的是内核中的真实线程id,  而pthread_self获取的是posix线程id, 不一样的。上述命令获取的线程id与gettid对应, 跟pthread_self没有毛关系。

       pthread_self不说了, 来看看gettid:

#include <stdio.h>
#include <sys/types.h>
#include <unistd.h>
#include <sys/syscall.h>
#define gettid() syscall(SYS_gettid)
#include <pthread.h>void* threadFunc(void* p)
{printf("threadFunc is %d\n",  gettid());int i = 0;while (1){sleep(1);}return NULL;}int main ()
{printf("main thread id is %d\n", gettid());pthread_t id;pthread_create (&id, NULL, threadFunc, NULL);pthread_create (&id, NULL, threadFunc, NULL);pthread_create (&id, NULL, threadFunc, NULL);pthread_create (&id, NULL, threadFunc, NULL);pthread_create (&id, NULL, threadFunc, NULL);pthread_create (&id, NULL, threadFunc, NULL);int i = 0;while (1){sleep(1);}return 0;
}

         编译:g++ test.cpp -lpthread

         运行起来, 然后查看一下:

ubuntu@VM-0-15-ubuntu:~$ ps -aux |grep a.out
ubuntu   26810  0.0  0.0  55692   696 pts/3    Sl+  20:12   0:00 ./a.out
ubuntu   26908  0.0  0.1  13228   972 pts/4    S+   20:13   0:00 grep a.out
ubuntu@VM-0-15-ubuntu:~$ 
ubuntu@VM-0-15-ubuntu:~$ ps -Tp 26810PID  SPID TTY          TIME CMD
26810 26810 pts/3    00:00:00 a.out
26810 26811 pts/3    00:00:00 a.out
26810 26812 pts/3    00:00:00 a.out
26810 26813 pts/3    00:00:00 a.out
26810 26814 pts/3    00:00:00 a.out
26810 26815 pts/3    00:00:00 a.out
26810 26816 pts/3    00:00:00 a.out
ubuntu@VM-0-15-ubuntu:~$ 

       看到没: 主线程 + 6个子线程。 第二列就是线程id.  进程id和主线程id是相等的。

 

       看到这里, 有个疑问, 快速启动多个a.out进程, 如果进程id紧紧挨在一起, 那么线程id是不是就重叠了呢?

       我快速开启4个a.out进程, 来看看:

ubuntu@VM-0-15-ubuntu:~$ ps -aux | grep a.out 
ubuntu   27224  0.0  0.0  55692   752 pts/6    Sl+  20:18   0:00 ./a.out
ubuntu   27232  0.0  0.0  55692   700 pts/5    Sl+  20:18   0:00 ./a.out
ubuntu   27239  0.0  0.0  55692   692 pts/4    Sl+  20:18   0:00 ./a.out
ubuntu   27247  0.0  0.0  55692   692 pts/3    Sl+  20:18   0:00 ./a.out

         可以看到, 进程id并没有紧挨在一起, 给线程id留了空隙, 有点意思。

 

         最后思考一个问题:进程的线程id一定是如上所示的连续的吗?

         当然不一定!

 

      

这篇关于如何获取进程的线程id?------说说gettid与pthread_self的区别的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/684071

相关文章

python获取指定名字的程序的文件路径的两种方法

《python获取指定名字的程序的文件路径的两种方法》本文主要介绍了python获取指定名字的程序的文件路径的两种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 最近在做项目,需要用到给定一个程序名字就可以自动获取到这个程序在Windows系统下的绝对路径,以下

Vue和React受控组件的区别小结

《Vue和React受控组件的区别小结》本文主要介绍了Vue和React受控组件的区别小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录背景React 的实现vue3 的实现写法一:直接修改事件参数写法二:通过ref引用 DOMVu

SpringBoot 获取请求参数的常用注解及用法

《SpringBoot获取请求参数的常用注解及用法》SpringBoot通过@RequestParam、@PathVariable等注解支持从HTTP请求中获取参数,涵盖查询、路径、请求体、头、C... 目录SpringBoot 提供了多种注解来方便地从 HTTP 请求中获取参数以下是主要的注解及其用法:1

Java中如何正确的停掉线程

《Java中如何正确的停掉线程》Java通过interrupt()通知线程停止而非强制,确保线程自主处理中断,避免数据损坏,线程池的shutdown()等待任务完成,shutdownNow()强制中断... 目录为什么不强制停止为什么 Java 不提供强制停止线程的能力呢?如何用interrupt停止线程s

python 线程池顺序执行的方法实现

《python线程池顺序执行的方法实现》在Python中,线程池默认是并发执行任务的,但若需要实现任务的顺序执行,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋... 目录方案一:强制单线程(伪顺序执行)方案二:按提交顺序获取结果方案三:任务间依赖控制方案四:队列顺序消

Go之errors.New和fmt.Errorf 的区别小结

《Go之errors.New和fmt.Errorf的区别小结》本文主要介绍了Go之errors.New和fmt.Errorf的区别,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考... 目录error的基本用法1. 获取错误信息2. 在条件判断中使用基本区别1.函数签名2.使用场景详细对

Redis中哨兵机制和集群的区别及说明

《Redis中哨兵机制和集群的区别及说明》Redis哨兵通过主从复制实现高可用,适用于中小规模数据;集群采用分布式分片,支持动态扩展,适合大规模数据,哨兵管理简单但扩展性弱,集群性能更强但架构复杂,根... 目录一、架构设计与节点角色1. 哨兵机制(Sentinel)2. 集群(Cluster)二、数据分片

Linux系统管理与进程任务管理方式

《Linux系统管理与进程任务管理方式》本文系统讲解Linux管理核心技能,涵盖引导流程、服务控制(Systemd与GRUB2)、进程管理(前台/后台运行、工具使用)、计划任务(at/cron)及常用... 目录引言一、linux系统引导过程与服务控制1.1 系统引导的五个关键阶段1.2 GRUB2的进化优

一文带你迅速搞懂路由器/交换机/光猫三者概念区别

《一文带你迅速搞懂路由器/交换机/光猫三者概念区别》讨论网络设备时,常提及路由器、交换机及光猫等词汇,日常生活、工作中,这些设备至关重要,居家上网、企业内部沟通乃至互联网冲浪皆无法脱离其影响力,本文将... 当谈论网络设备时,我们常常会听到路由器、交换机和光猫这几个名词。它们是构建现代网络基础设施的关键组成

redis和redission分布式锁原理及区别说明

《redis和redission分布式锁原理及区别说明》文章对比了synchronized、乐观锁、Redis分布式锁及Redission锁的原理与区别,指出在集群环境下synchronized失效,... 目录Redis和redission分布式锁原理及区别1、有的同伴想到了synchronized关键字