当我尝试将一个function1分配给另一个function1时,Boost :: function会给我一个十次异常。
任务是boost::function1<void, void*>
的typedef。
以下是具体代码:
// the Task object sent in as Task task
void Sleeper(void* arg)
{
int32_t sleepTime = *(int32_t*)arg;
SleepCurrentThread((int32_t)sleepTime);
}
struct ThreadInfo
{
ThreadInfo() : mState(DETACHED), mTask(NULL), mArg(NULL)
{ }
ThreadState mState;
Task mTask;
void* mArg;
};
Thread::Thread(Task task, void* arg, IMemoryAllocator& allocator, ILogManager& logger) : mAllocator(allocator), mLogger(logger)
{
mThreadInfo = (ThreadInfo*) mAllocator.Allocate(sizeof(ThreadInfo)); // simnple heap allocation
mThreadInfo->mArg = arg;
mThreadInfo->mState = Thread::RUNNING;
mThreadInfo->mTask = task; //<--------- throws... sometimes
mHandle = _CreateThread(&Run, (void*)mThreadInfo);
if (!mHandle)
Detach();
}
我特意在boost function_template.hpp中将它跟踪到赋值运算符,在此代码中最终抛出:
// Assignment from another BOOST_FUNCTION_FUNCTION
BOOST_FUNCTION_FUNCTION& operator=(const BOOST_FUNCTION_FUNCTION& f)
{
if (&f == this)
return *this;
this->clear();
BOOST_TRY {
this->assign_to_own(f); // <--- throws, and then line below re-throws
} BOOST_CATCH (...) {
vtable = 0;
BOOST_RETHROW;
}
BOOST_CATCH_END
return *this;
}
这是为什么?是否有任何容易发现我的代码有问题?还有什么需要吗?
由于
编辑:我知道我会被要求使用boost :: threads,但我正在尝试使用自己的win32 / pthread包装器,(为了好玩)答案 0 :(得分:5)
你的struct
有一个非平凡的构造函数,但是你没有调用它。它使Task
成员未初始化。要初始化它,要么使用new
分配整个对象,要么使用placement new来初始化它,如下所示:
void *mem = mAllocator.Allocate(sizeof(ThreadInfo)); // simnple heap allocation
mThreadInfo = new(mem) ThreadInfo; // placement new
mThreadInfo->mArg = arg;
mThreadInfo->mState = Thread::RUNNING;
mThreadInfo->mTask = task;
Placement new在已分配的原始(未初始化)内存中构造对象。