ThreadCurrentThread
获得的就是执行改方法的线程,你肯定是开了很多线程,线程有自己的线程ID,你可以通过打印的方式将线程ID打印出来看看是不是结束正确的。
我不明白你所表述的代码逻辑,但是ThreadCurrentThread
绝对得到的是执行该方法的线程。
通过查看资料,发现一种比较简单的方法就是在代码中使用printf将当前线程的id打印出来。
而这也分成两种情况:
1 如果是pthread,则使用,
#include <pthreadh>
pthread_t pthread_self(void);
2 如果不是pthread,即是由内核创建的线程,则使用,
#include <sys/typesh>
pid_t gettid(void);
获取线程所在的进程的id,方法如下:
#include <sys/typesh>
#include <unistdh>
pid_t getpid(void);
pid_t getppid(void);
所以,我们在代码中使用如下的语句打印:
printf("\ntid=%lu, pid=%lu\n", gettid(), getpid());
这样就能获取当前代码所在的线程和进程了。
根据打印出来的进程的pid,获取进程名的方法是:
ls -lh /proc/pid/exe
lrwxrwxrwx 1 root root 0 Jan 1 20:48 /proc/pid/exe ->
sh-32#
查看thread id的方法有:
1 sh-32# ps -efL | grep process,
ps命令指定-L命令选项可以用来查看进程下所包含的所有线程。
2 sh-32# ls -l /proc/pid/task/
查看进程下当前有哪些task,这些task指的就是线程。
线程是进程内部的一个执行单元,一个进程可以有多个线程,但是这些线程仅存在于该进程中,纯种是在它所属的进程地址空间里执行的,并在进程的地址空间对数据进行 *** 作。
输入下面的语句:
Requirements
Client
Requires Windows Vista
Server
Requires Windows Server 2008 or Windows Server 2003
Header
Declared in Winbaseh; include Windowsh
Library
Use Kernel32lib
DLL
Requires Kernel32dll
GetWindowThreadProcessId,它根据窗口的句柄来获取进程和线程ID,VB原型如下
'Private Declare Function GetWindowThreadProcessId Lib "user32" (ByVal hwnd As Long, lpdwProcessId As Long) As Long
'参数:
'hwnd:目标窗口的句柄
'lpdwProcessId:一个接受返回进程ID的Long变量,
'顺便提一下,在我们调用API的时候,如果一个变量不是ByVal传递,则表示这个变量是用来接受返回值的(但也不是绝对的)
'返回值:
'窗口的线程ID
pthread_create 的第一个参数就是线程id。
pthread_self 的返回值和pthread_create的第一个返回参数的值是一样的
你要的线程id就是通过这两个函数获取的。
看一下linux下的帮助吧 man pthread_self 至于为什么ps -eLf 的线程id对不上,这个我不太清楚。但可以肯定的是,你用的接口应该是对的。
以上就是关于C# 如何获取当前方法所在的线程全部的内容,包括:C# 如何获取当前方法所在的线程、如何获取linux内核线程的pid、已知一个线程ID,如何得到该线程所属的进程ID等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)