草庐IT

concurrent

全部标签

java - 是否有与 java.util.concurrent.locks.ReentrantReadWriteLock 等效的 C++?

我想控制对一组数据类的getter和setter的访问,使它们可以同时从多个线程安全地访问。我之前在Java中使用java.util.concurrent.locks.ReentrantReadWriteLock完成过此操作,非常轻松。但是现在我在我当前的C++项目中遇到了很多麻烦,因为我找不到可重入的读/写锁实现。具体来说,我想要一个允许线程在已经拥有写锁的情况下获得读锁,而不会阻塞且不会先放弃写锁。原因很简单:我的一些setter方法调用getter方法,前者(通常)获得写锁,后者获得读锁。我不想为了解决锁类中的限制而扭曲我简单的getter/setter架构。我试过Qt(4.8)

c++ - std::thread::hardware_concurrency 和静态初始化

这个全局函数是否会遭受静态初始化失败?templatevoidParallelFor(intiIni,intiFin,TFnFn){staticconstunsignedintNThread=std::thread::hardware_concurrency();//...} 最佳答案 Maythisglobalfunctionsufferfromstaticinitializationfiasco?不,不会。你很安全……:-)引用C++标准草案(强调我的)...$6.7:4:Dynamicinitializationofabloc

python - 为什么在使用 concurrent.futures.ProcessPoolExecuter() 进行多处理期间不止一次打印此消息?

“我应该只出现一次”这句话应该只出现一次。我无法理解为什么它又出现了3次...我很清楚我的代码正在执行3个进一步的进程。但是在这3个进程中,只有funktion0()被调用。为什么声明“我应该只出现一次”包含在这额外的3个进程中?有人可以解释一下吗?代码:fromdatetimeimportdatetime#print(datetime.now().time())fromtimeimporttime,sleep#print(time())print("Ishouldappearonlyonce")fromconcurrentimportfuturesdeffunktion0(arg0)

concurrency - 在单个 Redis 连接上交错 Watch Multi/exec。预期或奇怪的行为?

考虑一个前置应用程序,其中每个请求共享相同的Redis连接,我认为这是推荐的方式(?)。在这种情况下,我相信我看到了一些奇怪的watchmulti/exec行为。具体来说,我预计两个交易之一会因为乐观锁定失败而失败(即:watch守卫),但两个交易似乎都没有发脾气,但导致了错误的最终值。为了说明,请参阅以下人为设计的场景。它在Node中,但我相信这是一个普遍的事情。这并行运行2个进程,它们都更新一个计数器。(它基本上实现了在RedisDocs中看到的Watch的规范示例。预期结果是第一个进程导致增量1,而第二个进程更新失败并返回null。相反,结果是两个进程都将计数器更新为1。但是,一

asp.net-mvc - 雷迪斯 : New Keys not persisted in concurrent requests

我们在我们的应用程序中集成了Redis缓存,在正常情况下工作正常。最近,我们在我们的应用程序中发现了一个非常奇怪的问题,即在并发ajax请求的情况下,新添加的键会自动删除,并且修改后的键具有旧值。场景如下:Ajax请求1:-从数据库读取数据,大约需要5-6秒返回-在页面加载时触发(document.ready事件)Ajax请求2:-触发按钮点击-在session中设置值-在Ajax请求1完成之前完成Ajax请求3:-简单地读取session值-找到旧值,应该已经收到Ajax请求2设置的值所以这里的顺序是这样的:1)AjaxReq1触发并开始处理,2)AjaxReq2triggered,

concurrency - 使用redis捕获计数器的峰值

我有一个处理session的分布式系统(session的定义对于这个问题并不重要,除了要注意它是一个持续时间大于一秒的进程,通常要大得多),我想在哪里识别在给定时间段内并发处理的最大session数是多少。基本设置是一个Redis数据库,我在每次session开始时递增一个计数器,并在每次session结束时递减它。因此,计数器值表示任何给定时间点的当前并发数。我的问题是如何生成给定时间片内峰值(最大)并发的准确指标(例如,给定日期的最大并发是多少)。我想听听其他人如何解决这个问题,但我目前的做法是:session开始INCRcounter-name增加计数器的当前值递增命令的结果就是

concurrency - 使用 Celery 同时由两个工作进程运行的独特任务

我正在从事一个项目,该项目的目标是运行一个将任务发送到Celery队列的守护进程,Redis用作代理。每个任务必须一次处理一次(不允许并发)。为了执行此操作,我在我的守护进程中实现了以下代码,它充当Redis的锁:whileTrue:forfooinbar:ifnotself.redis_client.exists(foo.name):# SendthetasktotheCeleryqueuetask=celery_app.send_task('buzz',context={'name':foo.name})redis_client.send(foo.name,task.id)time

concurrency - Redis BITSET 和 WATCH

我正在使用Redis创建一种算法,用于从一个范围内声明未使用的整数。我的解决方案基于我对this得到的答案所以问题。此解决方案使用BITPOS和BITSET,为了避免竞争条件,我还使用了WATCH/MULTI/执行。为了测试并发方面,我创建了一个bash脚本,它同时尝试并行查找一个空闲号码10次,以调查EXEC命令的可能结果。我发现EXEC从未返回null,即使监视的键被另一个客户端修改了。我添加了延迟,以便有足够的时间来触发应该触发监视机制的并发修改,以便EXEC失败,但事实并非如此。所以基本上我有这段代码:while(true){WATCHmykeynumber=BITPOSmyk

concurrency - 当我并发运行 zadd 时,如何限制排序集的最大长度?

我想使用redis来存储这样的数据:{id:timestamp(1416991171)}在一个排序集中,它需要有一个最大长度。我只是在插入新的成员/值对之前检查排序集的长度。但我不确定这是否是确保最大长度的好主意,因为我将同时运行它。代码是这样的(在ruby​​中):key="list"max=5if$redis.zcard(key)如何保证最大长度?提前致谢。 最佳答案 注意:您的问题似乎有错字,因为您使用了key两次-一次用于排序集,一次用作标识符。我在回复中将标识符称为keyx。您有两种选择来确保您的SortedSet不会增长

ios - 对于 iOS,Concurrency Programming Guide 和 Threading Programming Guide 有什么区别?

我的问题背后的原因是我正在为iPhone编写一个音频单元托管应用程序,我需要同步来自音频线程(写入内存)和GUI线程(从内存读取)的内存访问。在寻找有关该主题的指南时,我发现苹果提供了两个iOS并行编程指南(类似的指南可用于OSX):ThreadingProgrammingGuideConcurrencyProgrammingGuide关于iOS,我是并行编程的新手;因此,我不清楚我需要阅读哪些指南,或者它们是否涵盖相同的问题。 最佳答案 并发编程指南将是您在调度API(又名GCD)和NSOperation方面的速成类(class)