枚举一个进程中的所有线程

枚举一个进程中的所有线程

作者:BlogUpdater |  时间:2023-07-01 |  浏览:756 |  评论已关闭 条评论

在 Win32 开发中,如果需要获取程序运行过程中的一些较为底层的信息,你可能需要使用到 Tool Helper 库。但我愿意称之它为 Win32 中的 “害群之马”。何解?

Tool Helper 库在 16 位 Windows 时代就已经存在了,这个库主要用来提供一些调试服务,例如获取调用堆栈和枚举系统中的所有内存等。

Win32 的初始版本中,并没有包含它,直到 Windows 95 之后,32 位版本的 Tool Helper 程序库才被引入到 Win32 中。

不管我们对它的评价如何,这些功能仍然存在,所以让我们试一试看看效果。

运行上面的程序,它会打印系统中所有线程的列表(或至少是你有权访问的所有线程)。

代码的逻辑还是挺简单的,唯一的微妙之处在于代码中的一个奇怪的检查,即 Thread32First 函数返回的大小足够大,可以包含我们需要的 th32OwnerProcessID 字段。这种复杂性是必要的,因为 Thread32First 和 Thread32Next 函数检查结构大小的方式有些非正统。

当一个 API 被认为是 Win32 API 的一匹害群之马时,就会发生上面的这种情况。

总结
一般我们会将应用程序的设置数据保存到注册表,这很方便,但是记得读取的时候,尽量只读一次并缓存结果,而不是每次都从注册表里读取,这对运行时性能是有伤害的。

最后
Raymond Chen的《The Old New Thing》是我非常喜欢的博客之一,里面有很多关于Windows的小知识,对于广大Windows平台开发者来说,确实十分有帮助。
本文来自:《Enumerating threads in a process》

最近我写了个东西
正如你们所知道的,拓扑梅尔智慧办公平台(Topomel Box)是一款绿色软件,主要面向经常使用电脑的朋友。它提供了各种提升办公效率的小功能,同时操作上尽可能地简单方便。
我想:你值得拥有。

标签:

评论已关闭。