GetThreadTimes获取其它线程cpu时间

来源:互联网 发布:mac ps2017怎么破解 编辑:程序博客网 时间:2024/06/03 13:23
http://www.cnblogs.com/eaglet/archive/2009/03/11/1408809.html鄙视下上面的垃圾博文,纯粹忽悠人
参考文章: http://blog.kalmbachnet.de/?postid=28 这是一个德国人写的博客,我看了好几遍,对他写的德式英语还是不太明白,(本人英文水平不高也是事实),所以我理解的不对的地方还望大家指正。不过结论肯定是正确的,就是通过GetThreadTimes 得到的线程占用时间是不准确的,在某种条件下甚至是很不准确的。 另外我发现调用GetThreadTimes获取其它线程的计数基本得不到,我还没有搞明白是什么原因。
搞不明白不去看官方文档!!!!!!!!!!!!查看msdn 里GetThreadTimes的文档http://msdn.microsoft.com/en-us/library/windows/desktop/ms683237(v=vs.85).aspx 
BOOL WINAPI GetThreadTimes(  _In_   HANDLE hThread,//需要获取cpu时间的线程句柄  _Out_  LPFILETIME lpCreationTime,//创建时间  _Out_  LPFILETIME lpExitTime,//退出时间  _Out_  LPFILETIME lpKernelTime,//内核时间  _Out_  LPFILETIME lpUserTime//用户时间);
hThread其计时信息寻求的线程的句柄。该句柄必须具有的 THREAD_QUERY_INFORMATION 或 THREAD_QUERY_LIMITED_INFORMATION 访问权。有关详细信息,请参见线程安全和访问权限。Windows Server 2003 和 Windows XP: 句柄必须具有的 THREAD_QUERY_INFORMATION 的访问权限。
在这篇文章
Thread Security and Access Rightshttp://msdn.microsoft.com/en-us/library/windows/desktop/ms686769(v=vs.85).aspx
里看到THREAD_QUERY_INFORMATION,结合说明得出THREAD_QUERY_INFORMATION是安全描述符的一个标志,所以又查看下面这篇文章学习如果创建使用
Creating a Security Descriptor for a New Object in C++ http://msdn.microsoft.com/zh-cn/library/aa446595.aspx
  
FILETIME ftKernelTimeStart, ftKernelTimeEnd;FILETIME ftUserTimeStart, ftUserTimeEnd;FILETIME ftDummy;HANDLE hThread;unsigned threadID;SECURITY_ATTRIBUTES saThread; PSECURITY_DESCRIPTOR pSD = NULL; //PSECURITY_DESCRIPTOR安全描述符pSD = (PSECURITY_DESCRIPTOR)LocalAlloc(LPTR,THREAD_QUERY_INFORMATION);if (NULL == pSD){_tprintf(_T("LocalAlloc Error %u\n"), GetLastError());}saThread.nLength = sizeof(saThread);saThread.lpSecurityDescriptor = pSD;hThread = (HANDLE)_beginthreadex(&saThread, 0, FirstThread, NULL, 0, &threadID);if(pSD)LocalFree(pSD);GetThreadTimes(hThread, &ftDummy, &ftDummy,&ftKernelTimeStart, &ftUserTimeStart);
  成功执行如下QQ截图20140212205741
1 0