给一个提升线程命名?

时间:2010-07-27 09:14:46

标签: c++ debugging boost-thread

是否可以为boost::thread命名,以便调试器表和崩溃日志更具可读性?怎么样?

2 个答案:

答案 0 :(得分:6)

您需要访问基础线程原语并以系统相关方式分配名称。调试和崩溃日志本质上是系统相关的,boost :: thread更多的是关于非系统依赖性,即关于可移植性。

似乎(http://www.boost.org/doc/libs/1_43_0/doc/html/thread.html)没有记录的方法来访问增强线程的底层系统资源。 (但我自己从未使用它,所以我可能会错过一些东西。)

编辑:(正如大卫在评论中写的那样)http://www.boost.org/doc/libs/1_43_0/doc/html/thread/thread_management.html#thread.thread_management.thread.nativehandle

答案 1 :(得分:4)

我在Win32 + VS2010上使用了boost 1.50.0而thread::native_handle包含的数字我没有设法与系统中的任何内容配对。另一方面,thread::get_id()方法以十六进制字符串的形式直接返回窗口线程ID。请注意,返回的值是特定于平台的。以下代码在Boost 1.50.0 + Win32 + VS2010下工作。从msdn

重用的部分代码
const DWORD MS_VC_EXCEPTION = 0x406D1388;
#pragma pack(push, 8)
typedef struct THREADNAME_INFO {
    DWORD dwType; // Must be 0x1000.
    LPCSTR szName; // Pointer to name (in user addr space).
    DWORD dwThreadID; // Thread ID (-1=caller thread).
    DWORD dwFlags; // Reserved for future use, must be zero.
} THREADNAME_INFO;
#pragma pack(pop)

void _SetThreadName(DWORD threadId, const char* threadName) {
    THREADNAME_INFO info;
    info.dwType = 0x1000;
    info.szName = threadName;
    info.dwThreadID = threadId;
    info.dwFlags = 0;
    __try {
        RaiseException( MS_VC_EXCEPTION, 0, sizeof(info)/sizeof(ULONG_PTR), (ULONG_PTR*)&info );
    }
    __except(EXCEPTION_EXECUTE_HANDLER) {
    }
}
void SetThreadName(boost::thread::id threadId, std::string threadName) {
    // convert string to char*
    const char* cchar = threadName.c_str();
    // convert HEX string to DWORD
    unsigned int dwThreadId;
    std::stringstream ss;
    ss << std::hex << threadId;
    ss >> dwThreadId;
    // set thread name
    _SetThreadName((DWORD)dwThreadId, cchar);
}

这样打电话:

boost::thread* thr = new boost::thread(boost::bind(...));
SetThreadName(thr->get_id(), "MyName");