本文整理汇总了C++中TaskPtr::GetId方法的典型用法代码示例。如果您正苦于以下问题:C++ TaskPtr::GetId方法的具体用法?C++ TaskPtr::GetId怎么用?C++ TaskPtr::GetId使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类TaskPtr
的用法示例。
在下文中一共展示了TaskPtr::GetId方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: RemoveTask
void VC::RemoveTask(const TaskPtr& task) {
//里面有并发控制机制
TaskState ts = task->GetTaskState();
assert(ts == TASK_WAIT || ts == TASK_RUN);
if(ts == TASK_WAIT) {
m_wait_queue.Erase(task->GetId());
} else {
m_run_queue.Erase(task->GetId());
}
}
示例2: KillTask
//这个错误处理是很麻烦的事情
void VC::KillTask(const TaskPtr& task) {
TaskState ts = task->GetTaskState();
assert(ts == TASK_WAIT || ts == TASK_RUN);
if(ts == TASK_WAIT) {
m_wait_queue.Erase(task->GetId());
} else {
try {
string endpoint = task->GetRunOn();
Proxy<WorkerClient> proxy = Rpc<WorkerClient, WorkerClient>::GetProxy(endpoint);
if(proxy().KillTask(task->GetId()) != 0) {
LOG4CPLUS_ERROR(logger, "delete task " << task->GetId() << " failed");
return;
}
m_run_queue.Erase(task->GetId());
} catch (TException &tx) {
LOG4CPLUS_ERROR(logger, "delte task error " << task->GetId() << " failed");
}
}
}