jjzjj

distributed-lock

全部标签

c++ - Fedora 22 - 编译 - __atomic_is_lock_free

我尝试在Fedora22上编译一个软件(SuperCollider),但我遇到了一个问题:libsupernova.a(server.cpp.o):Infunction`std::atomic::is_lock_free()const':/usr/include/c++/5.1.1/atomic:212:undefinedreferenceto`__atomic_is_lock_free'collect2:error:ldreturned1exitstatusserver/supernova/CMakeFiles/supernova.dir/build.make:96:recipefo

NameNode是Hadoop Distributed File System(HDFS)中的主服务器

NameNode是HadoopDistributedFileSystem(HDFS)中的主服务器,负责管理文件系统的元数据。以下是NameNode的具体职责:文件系统的一致性维护:NameNode负责管理HDFS的元数据,包括文件系统的目录树、文件和数据块的具体信息等。它确保整个文件系统的一致性,即任何时候都能提供准确的元数据信息。数据块的映射:NameNode维护着文件和数据块的映射关系。当客户端请求读取或写入文件时,NameNode会根据需要将数据块的位置信息提供给客户端,以支持文件的读取或写入操作。文件系统的目录结构:NameNode维护着整个文件系统的目录结构,包括目录的创建、删除和修

c++ - 为什么我们应该将 `std::unique_lock` 放在本地范围内?

基于C++EquivalenttoJava'sBlockingQueuevoidpush(Tconst&value){//originalversion{std::unique_locklock(this->d_mutex);d_queue.push_front(value);}this->d_condition.notify_one();}voidpush(Tconst&value){//myquestion//{//commentoutthescopestd::unique_locklock(this->d_mutex);d_queue.push_front(value);//}/

c++ - OS X libc++ std::uniform_real_distribution 错误

我在使用C++11的std::uniform_real_distribution编译AppleLLVM版本7.0.2(clang-700.1.81)时看到了一些奇怪的行为。调用operator()会呈现超出分布范围的结果。下面的最小示例程序重现了这个问题//Exampleprogram#include#include#includetemplateconstexpruint64_tpower_of_two(){return2*power_of_two();}templateconstexpruint64_tpower_of_two(){return1;}std::linear_cong

c++ - boost::scoped_lock 不适用于局部静态变量?

我制作了以下示例程序来使用boost线程:#pragmaonce#include"boost\thread\mutex.hpp"#includeclassThreadWorker{public:ThreadWorker(){}virtual~ThreadWorker(){}staticvoidFirstCount(intthreadId){boost::mutex::scoped_lock(mutex_);staticinti=0;for(i=1;i主类://ThreadTest.cpp#include"stdafx.h"#include"boost\thread\thread.hpp

C++:具有 `std::lock_guard` 的互斥量是否足以同步两个 `std::thread`?

我的问题是基于下面的C++代码示例#include#include#include#includeclassClassUtility{public:ClassUtility(){}~ClassUtility(){}voiddo_something(){std::coutlock(g_mutex);std::coutlock(g_mutex);std::cout如果需要,这更像是一个问题,目的是让我的理解更清楚,并获取std::condition_variable的示例用法。我有2个C++std::thread,它们在main方法中启动。它是osx上的控制台应用程序。所以使用clang编

c++ - std::mt19937 和 std::uniform_real_distribution 每次都返回边界值

好的,所以我有一些RNG代码(当一切都说完了)归结为:#include#include#include#includedoublerandomValue(){//SeedaMersenneTwister(goodRNG)withthecurrentsystemtimestd::mt19937generator(std::chrono::system_clock::now().time_since_epoch().count());std::uniform_real_distributiondist(std::numeric_limits::lowest(),std::numeric_l

c++ - 如何在 boost::unique_lock<boost::mutex> 上尝试锁定

根据标题,如何在boost::unique_lock上尝试锁定?我有这段代码:voidmySafeFunct(){if(myMutex.try_lock()==false){return-1;}//mutexownershipisautomaticallyacquired//dostuffsafelymyMutex.unlock();}现在我想使用unique_lock(它也是一个作用域互斥体)而不是普通的boost::mutex。我希望这样可以避免函数体中的所有unlock()调用。 最佳答案 您可以使用Deferconstruc

c++ - std::lock_guard<std::mutex> 施工段错误?

我正在尝试使用std::mutex和std::lock_guard访问共享的std::queue。mutex(pending_md_mtx_)是另一个对象(其地址有效)的成员变量。我的代码似乎在lock_guard的构造上出现了段错误。有什么想法吗?我应该改用std::unique_lock(或其他对象)吗?在UbuntuLinux下运行GCC4.6(--std=c++0x)。我无法发布整个类(class),但只能访问下面列出的互斥锁和队列。templateclassDriver{public:templateDriver(Args&&...args):listener_(std::f

C++ weak_ptr.lock() 段错误

所以我有这个函数来添加监听器,它转换一个类的共享指针,以便我稍后在收到通知时可以调用它。voidregisterListener(std::shared_ptrlistener){if(!listener){qCWarning(OBSERVER_LOGGER)lock()){if(listener==shared){return;}iter++;}else{iter=listeners.erase(iter);}}autoweak=std::weak_ptr(listener);listeners.push_back(weak);}voidnotify(std::function)>o