- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我有 NUM_THREADS 个线程,线程中有以下代码:
/*
Calculate some_value;
*/
//Critical section to accummulate all thresholds
{
boost::mutex::scoped_lock lock(write_mutex);
T += some_value;
num_threads++;
if (num_threads == NUM_THREADS){
T = T/NUM_THREADS;
READY = true;
cond.notify_all();
num_threads = 0;
}
}
//Wait for average threshold to be ready
if (!READY)
{
boost::unique_lock<boost::mutex> lock(wait_mutex);
while (!READY){
cond.wait(lock);
}
}
//End critical section
/*
do_something;
*/
基本上,我希望所有线程在继续之前等待 READY 信号。 num_thread 设置为 0,并且在创建线程之前 READY 为 false。偶尔会发生死锁。有人可以帮忙吗?所有的boost变量都全局声明如下:
boost::mutex write_mutex;
boost::mutex wait_mutex;
boost::condition cond;
最佳答案
代码在 READY
标志上有一个竞争条件(我假设它只是一个 bool
变量)。可能发生的情况(即线程执行交错的一种可能变体)是:
Thread T1: Thread T2:
if (!READY)
{
unique_lock<mutex> lock(wait_mutex); mutex::scoped_lock lock(write_mutex);
while (!READY) /* ... */
{ READY = true;
/* !!! */ cond.notify_all();
cond.wait(lock);
}
}
测试 READY
标志的代码与设置它的代码不同步(注意这些关键部分的锁是不同的)。当 T1 处于标志测试和等待 cond
之间的“空洞”时,T2 可能会设置标志并向 cond
发送信号,而 T1 可能会错过。
最简单的解决方案是为 READY
的更新和条件通知锁定正确的互斥量:
/*...*/
T = T/NUM_THREADS;
{
boost::mutex::scoped_lock lock(wait_mutex);
READY = true;
cond.notify_all();
}
关于c++ - 升压同步,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9014374/
在 Java 中,我可以在不指定类型的情况下定义泛型类的变量。 class Tree> {} somewhere-else: Tree tree; 然后我可以从文件中读入一些对象并将其类型转换为我想要
我昨天发布了一个问题,我使用 multi_map 解决了这个问题: Having a composite key for hash map in c++ 这很有效,但是当数据足够大时就会出现问题。 我
这应该很简单(我只是在学习 boost,所以我错过了一些东西) 我已经使用 json_read 读取了一些简单的 JSON,现在有了一个 ptree。网络上的所有示例都显示使用 ptree.get("
所以我的问题很简单,在我的词法分析器类(扩展 lex::lexer )中,我有以下内容; this->self.add ... ("&&", AND_AND) ("||", O
关于这个问题有很多问题,但似乎没有一个能解决我的问题。我不认为这真的是一个 Boost::Variant 问题;我很确定我只是以错误的方式使用了模板。我能够剥离代码,以便您可以编译它并自己查看问题,这
这个问题确定不可复制类型不能与 Boost Variant 一起使用 树类 template class Tree{ private: class TreeNode{
我有一个用于解析标识符的解析器,如 foo, bar, baz 和一个用于解析嵌套标识符的解析器,如 foo::bar, foo::bar.baz, foo::bar.baz.baham它们都解析为相
通过阅读其他 Stack Overflow 条目和 boost::asio 文档,我确认没有同步 ASIO 读/写调用也提供易于使用的超时作为调用的参数。 我正在使用使用超时的 select(2) 调
我应该在我的 jamroot.jam 文件中放入什么,以便 libAPLibrary.so 与 MyProject 编译的结果相关联? root |-MyProject | |-jamroot
我有一个 vector,我想将其插入到一个 set 中。这是三个不同的调用之一(另外两个更复杂,涉及 boost::lambda::if_()),但解决这个简单的案例将帮助我解决其他问题。 std::
我确定套接字在我的应用程序中的任何地方都关闭了,并且我不断在我的/proc/pid/fd/下获取这个新创建的 fd/socket 文件,这是正常的。我确定不是。 connection.cpp con
元组是由括号括起来的逗号分隔列表,例如 () (,) (thing,) (2,3) 如果我有 #define ISTUPLE(x) \\... 我想要类似 ISTUPLE(nope) 的东西解析为 0
我有一个问题,两个线程是这样调用的,一个接一个。 new boost::thread( &SERVER::start_receive, this); new boost::thread( &SERVE
遇到 Boost 程序选项问题。我添加了一个多次使用选项,我们称之为“--opt”。当我从命令行使用两个“--opt”运行program.exe时,我从boost中收到以下错误。 terminatin
我想用类似于 C 的转义规则来解析字符串。我想保留转义,而不是解码它们然后重新编码。所以我认为 *(char_('\\') >> char_ | char_ - '"') 会做我想做的事,但事实并非如
聊天程序就是一个很好的例子。只需要一个可以接受来自客户端的多个连接的服务器,并且该服务器需要能够向各个客户端发送消息。 我计划将它变成一个分布式计算程序,以使用多个神经网络。 最佳答案 Asio是处理
我是一名优秀的程序员,十分优秀!