jjzjj

synchronization

全部标签

concurrency - 潜在递归任务的工作池(即,每个作业都可以排队其他作业)

我正在编写一个应用程序,用户可以从多个“作业”(实际上是URL)开始。在开始(主例程)时,我将这些URL添加到队列中,然后启动x个处理这些URL的goroutines。在特殊情况下,URL指向的资源可能包含更多必须添加到队列中的URL。这3名worker正在等待新工作的到来并处理它们。问题是:一旦每个worker都在等待工作(并且没有人在生产),worker应该完全停止。因此,要么所有人都工作,要么没有人工作。我当前的实现看起来像这样,但我认为它并不优雅。不幸的是,我想不出一个不包含竞争条件的更好方法,而且我不完全确定这个实现是否真的按预期工作:varqueue//fromsomewh

go - 集群中 n 个 Web 服务器之间的文件同步

Web集群中有n个节点。文件可以上传到任何节点,然后必须分发到每个其他节点。这种分布不必在事务中发生(事实上它不能,分布式事务不能扩展)并且一些延迟是可以接受的,尽管必须是最小的。可以任意解决冲突(通常最后写入获胜),前提是解决方案也分发给所有节点,以便最终所有节点都具有相同的文件集。可以动态添加和删除节点,而无需重新配置现有节点。必须没有单点故障,也不需要额外的盒子来解决这个问题(比如RabbitMQ)我正在考虑使用consul.io进行动态配置,以便每个节点都可以引用consul来确定其他可用的节点,并编写一个守护进程(Golang)来监视相关文件夹并使用其他节点进行通信零MQ。虽

java - 我将如何在 Java 中实现 Go 的无缓冲 channel ?

Go同时提供unbufferedandbufferedchannels用于goroutines(线程)之间的通信。是straightforward在Java中将缓冲channel实现为有界缓冲区。Go的无缓冲channel要求一个协程在另一个协程接收时发送。任何人都可以向我解释如何在Java中实现它吗? 最佳答案 在Java中你可以使用SynchronousQueue,Java8的源代码在这里http://grepcode.com/file/repository.grepcode.com/java/root/jdk/openjdk/

go - 初始化 map 元素,其中值是具有互斥锁 golang 的结构

我有一个映射,其中每个值都是指向另一个本身有锁的结构的指针。typeStatMapmap[string]*StatstypeStatsstruct{sync.RWMutexsomeStats,someMoreStatsfloat64}我已经实现了一种方法,我将StatMap打包到另一个结构中并为整个map设置互斥锁,但我希望从数百个goroutines中同时修改map中的每个条目,因此它会更有效锁定映射中的每个元素,以便两个或多个goroutine可以并行读取和修改条目的值。我想知道的是,每当出现新key时,我如何才能在map中初始化一个新条目?如果条目不在map中,我无法锁定该条目,

尽管有锁,Go 仍检测到 map 上的并发读写

我正在编写一个简单的缓存机制,它有一个Add、一个Evict和一个Search方法。Search目前尚未实现,因此无需担心。调用Add添加数据的goroutine数量较多,只有一个goroutine运行在evict循环中逐出数据。一旦我对它施加一些严重的流量,Go就会抛出并说在mapmetricCache上有并发的读写访问,但我看不出这是怎么发生的,因为它周围有锁。我正在使用Go1.7。文件mdata/cache.go:57:funcNewCCache()*CCache{58:cc:=&CCache{59:lock:sync.RWMutex{},60:metricCache:make(

recursion - 通过 WaitGroup 编排递归快速排序调用

我正在尝试并行运行递归快速排序调用:funcquicksort(a[]int){quicksortRecursive(a)wg.Wait()insertionsort(a)}funcquicksortRecursive(a[]int){iflen(a)>THRESHOLD{l,r:=partition(a)wg.Add(2)gofunc(){quicksortRecursive(a[:r+1])wg.Done()}()gofunc(){goquicksortRecursive(a[l:])wg.Done()}()}}go调用对我来说显得过于笨重。以下更具可读性的版本是否仍然正确?fun

testing - 在涉及全局变量的不同包中同步测试的最佳方法是什么?

我正在做一个go项目,我的任务是为一个包编写一些测试。测试需要访问不同包中的全局变量。这个全局变量可能在不同包的测试中设置/访问。因为默认情况下,gotesting会针对不同的包并行运行。因此,设置/访问此变量可能会产生竞争条件。最简单的同步方法是创建一个跨越不同包的共享sync.Mutex。话虽如此,我试图将这个sync.Mutex放在声明全局变量的xxx.go的xxx_test.go中,不幸的是,由于作用域,另一个包无法访问这个Mutex局限性。最终,我发现我必须将这个sync.Mutex放到一个专门用于测试的实用程序包中,然后不同的包可以访问这个Mutex以实现该全局变量的同步目

Java Fluent API - 更好的方法?

假设我创建了一个对象来进一步简化使用DOM解析器读取XML文档的过程。为了“进入”一个节点或元素,我想使用一行从文档的开头到我的目标数据,埋在文档中的某个地方,同时绕过DOM的额外“绒毛”解析器(例如doc.getElementsByTagName("data").item(0),当“data”元素中只有一项时)。为了这个问题,我们假设没有重复的元素标签,并且我知道我需要导航到哪里才能从文档中获取我需要的数据,其中的数据是一个简单的字符串。这个想法是设置简化阅读器,以便它也可以用于文档中其他位置的其他数据,而不必一直编写新方法。下面是我试过的一些示例代码:publicclassSimp

xml - 柔性 3 : synchronously loading an xml file

我的问题很简单:在flex3中,有没有办法同步加载一个xml文件?我知道如何使用加载事件异步加载。这可能有用,也可能没有用。我只想读取文件,解析它,做我必须做的事情,然后继续执行代码。我有一个使用xml文件存储一些配置参数的组件。我需要在初始化对象时读取文件。但是,使用事件模型,我无法控制文件何时加载,所以我必须编写代码来“等待”代码加载。这太荒谬了,还是我?我想要这样的代码:varfoo:Foo=newFoo();//Thisconstructorshouldreadthexmlandinitializetheobject.foo.doSomething();//WhenIcallt

.NET:向同一应用程序的所有实例发送文本消息并阅读

我需要能够在我的应用程序的所有运行实例之间可靠地同步一些文本数据block。最好的制作方法是什么? 最佳答案 一般来说,您需要ObserverPattern.你需要一些东西来充当服务器。之后,取决于某个应用程序发生的更改是否应该通知观察者,或者观察者是否应该从每个客户端(在某些时间间隔)请求更改摘要,将其合并并将其返回给客户端。用您提供的最少信息来回答太复杂了。 关于.NET:向同一应用程序的所有实例发送文本消息并阅读,我们在StackOverflow上找到一个类似的问题: