草庐IT

thunder-lock

全部标签

c++ - mutex lock fail with invalid argument 是什么意思?

此代码在我的主进程中调用并编译正常,但在执行时总是抛出以下错误。bounded_bufferbb(200);Producer>producer(&bb);boost::threadproduce(producer);//throwsonthisline这里是执行时总是出现的错误。terminatecalledafterthrowinganinstanceof'boost::exception_detail::clone_impl>'what():boost:mutexlockfailedinpthread_mutex_lock:Invalidargument'classbounded_

c++ - 自旋锁与 std::mutex::try_lock

使用专门设计的自旋锁(例如http://anki3d.org/spinlock)与这样的代码相比有什么好处:std::mutexm;while(!m.try_lock()){}#doworkm.unlock(); 最佳答案 在典型的硬件上,有很多好处:您天真的“假自旋锁”可能会在CPU旋转时使内部CPU总线饱和,从而使其他物理内核(包括持有锁的物理内核)处于饥饿状态。如果CPU支持超线程或类似的东西,您天真的“假自旋锁”可能会消耗物理内核上的过多执行资源,使共享该物理内核的另一个线程处于饥饿状态。您天真的“假自旋锁”可能会执行无关的

c++ - `std::mutex` 和 `std::lock` 是否保证处理器间代码中的内存同步?

我目前正在使用openMP编写在多核节点上运行的代码。openMP有一个特定的内存模型,保证在获取锁时在不同内核上运行的线程之间内存是同步的。我考虑使用C++11构造(std::threadwithstd::mutexandstd::lock)而不是openMP(因为它们更大的灵active)并想知道处理器之间的内存同步是否/如何在这里得到保证?如果没有,我该如何执行? 最佳答案 该标准在§30.4.1.2[thread.mutex.requirements.mutex]/6-25中对std::mutex的同步做出了以下保证Thee

c++ - is_lock_free 未在 gcc 4.7.2 的 std::atomic<T> 中定义?

我遇到这个编译器错误functionstd::atomic::is_lock_free()const:error:undefinedreferenceto'__atomic_is_lock_free'whencompilingcodelikebelowusinggcc4.7.2onlinux.structS{inta;intb;};std::atomics;cout 最佳答案 AtomicAPIisn'tcompleteinGCC4.7:Whenlockfreeinstructionsarenotavailable(eitherth

c++ - std::unique_lock::release 的用例是什么?

在什么情况下会使用std::unique_lock的release方法?我错误地使用了release方法而不是unlock方法,我花了一段时间才明白为什么下面的代码不起作用。#include#include#include#include#includestd::mutexmtx;voidfoo(){std::unique_locklock(mtx);std::coutthreads;for(inti=0;i 最佳答案 它在thisanswer中有很好的用途其中锁定状态的所有权明确地从函数本地unique_lock转移到外部实体(通

c++ - std::unique_lock 和 std::condition_variable 如何工作

我需要弄清楚lock和condition_variable是如何工作的。在此处的-稍微修改过的代码中cplusplusreferencestd::mutexm;std::condition_variablecv;std::stringdata;boolready=false;boolprocessed=false;voidworker_thread(){//Waituntilmain()sendsdatastd::unique_locklk(m);cv.wait(lk,[]{returnready;});//afterthewait,weownthelock.std::coutlk(m

c++ - std::lock_guard 导致未定义的行为

编辑:看起来,问题是我实际上并没有创建一个lock_guard的本地实例,而只是一个匿名的临时实例,它立即再次被销毁,如下面的评论所指出的。Edit2:启用clang的线程清理器有助于在运行时查明这些类型的问题。它可以通过启用clang++-std=c++14-stdlib=libc++-fsanitize=thread*.cpp-pthread这在某种程度上可能是一个重复的问题,但我找不到任何东西,所以如果它真的是重复的,我很抱歉。无论如何,这应该是一个初学者问题。我正在玩一个简单的“Counter”类,比如在文件中内联计数器.hpp:#ifndefCLASS_COUNTER_HPP

c++ - std::lock_guard 有什么问题

我有简单的代码:第一个线程将std::strings推送到std::list,第二个线程弹出std::strings从这个std::list。所有std::list的操作都受到std::mutexm的保护。此代码将错误永久打印到控制台:"Error:lst.begin()==lst.end()"。如果我将std::lock_guard替换为构造m.lock()和m.unlock()代码将开始正常工作。std::lock_guard有什么问题?#include#include#include#include#includestd::mutexm;std::listlst;voidf2()

c++ - boost scoped_lock 互斥锁崩溃

我已经保护了一个std::queue的访问函数,push、pop、size,在这些函数中使用boost::mutexes和boost::mutex::scoped_lock有时它会在作用域锁中崩溃调用栈是这样的:00x0040f005boost::detail::win32::interlocked_bit_test_and_setinclude/boost/thread/win32/thread_primitives.hpp36110x0040e879boost::detail::basic_timed_mutex::timed_lockinclude/boost/thread/wi

c++ - 使用 boost::interprocess::file_lock 创建一个锁定文件

我想使用boost::interprocess::file_lock来确保进程P1写入目录x的文件>在完成之前不会被进程P2读取。为此,我想让P1在写入文件时使用boost::interprocess::file_lock锁定文件,然后在完成后解锁它们。然后P2可以跳过(并返回)任何被锁定的文件。我遇到的问题是boost::interprocess::file_lock似乎只允许您锁定存在的文件。但是,如果我先创建文件,然后将其锁定,则会出现竞争条件:P1创建文件P2注意到文件并开始读取它P1锁定文件P1写入一些数据P2读取一些数据,到达最后,最后只有P1的部分输出。所以我想做的是创建