草庐IT

开放原子

全部标签

javascript - increment 是 JavaScript 中的原子操作吗?

increment是JavaScript中的原子操作吗?如果一个线程正在访问++i;同时另一个开始访问运行会不会有什么问题? 最佳答案 在JavaScript中,函数总是运行到完成。这意味着如果一个函数正在运行,那么它将完全运行;只有在那之后,另一个函数才会被调用。因此,语句之间没有交错的机会(但在Java中则不同)。如果您对异步执行感到困惑,请始终记住async意味着以后不是并行的。所以,对于您的问题,答案是,不,您不会遇到任何问题,这将是一个完整的原子操作。 关于javascript

go - append() 在原子/线程中是安全的吗?

阅读几个列表后,我想将每个列表中的所有行添加到一个大数组中。我在它自己的goroutine中运行每个列表阅读器。我可以在阅读后立即追加一行吗?这个线程是保存还是可以在我手中爆炸?typelistHolder{entries[]entry}func(h*listHolder)readAllLists(s[]list){c:=make(chanlist)varwgsync.WaitGroupfor_,l:=ranges{wg.Add(1)goh.readSomeList(&wg,l)}c.close()wg.Wait()}func(h*listHolder)readSomeList(wg*

github - golang 中非原子类型的类型包装

我是golang的新手,正在尝试理解“非原子”类型time.Time的类型包装代码示例。有问题的类型扩展来自github上GDAX的Go客户端,go-coinbase-exchangeproject。预期的行为是来自项目(coinbase.Time)的时间变量,它们属于typeTimetime.Time(在项目的time.go文件中定义),其行为类似于以下用于扩展“原子”类型int(来自blog.riff.org,因为它们可能会遵循一种来自基类型的“继承”,用于像Time.format这样的函数(来自golang'sstandardimplementationoftime:packag

golang 同步/原子包?

我写了一段代码记录请求数。packagemainimport("log""net/http""runtime""sync/atomic")varcountint32=0functest(whttp.ResponseWriter,r*http.Request){count=atomic.LoadInt32(&count)atomic.AddInt32(&count,1)log.Println("count:",count)}funcmain(){runtime.GOMAXPROCS(runtime.NumCPU()-1)http.HandleFunc("/",test)http.List

go - 定义类型的原子操作

如果我像这样定义一种新的“状态”:typeStateint32“State”类型的值可以应用于原子操作,例如“atomic.StoreInt32()”吗?如果不是,为什么?如果可以,是否可以按如下方式应用?funcSetAndGet(sState,nState)State{si:=int32(s)ni:=int32(n)returnState(atomic.SwapInt32(&si,ni))}更新:代码根据@icza的回答修改如下funcSetAndGetState(s*State,nState)State{returnState(atomic.SwapInt32((*int32)(

go - 同步原语原子包

Go中的同步包有Once原语。Do()方法实现了func(o*Once)Do(ffunc()){ifatomic.LoadUint32(&o.done)==1{return}//Slow-path.o.m.Lock()defero.m.Unlock()ifo.done==0{deferatomic.StoreUint32(&o.done,1)f()}}为什么我不能使用此方法的其他版本?func(o*Once)Do(ffunc()){ifo.done==1{return}//Slow-path.o.m.Lock()defero.m.Unlock()ifo.done==0{deferato

go - 原子 AddUint32 溢出

我正在使用以下代码在进程中获取唯一ID:fori:=0;i如果计数器值溢出uint32的限制会发生什么? 最佳答案 值环绕,很容易证明:u:=uint32(math.MaxUint32)fmt.Println(u)u++fmt.Println(u)//oru=math.MaxUint32atomic.AddUint32(&u,1)fmt.Println(u)https://play.golang.org/p/lCOM3nMYNc 关于go-原子AddUint32溢出,我们在StackOv

go - 如何在 Go 中将 time.Time 变量转换为原子变量?

在我的在线游戏RESTFUL网络服务中,我将每个问题的开始时间存储在一个全局变量中,如下所示:varMyTimetime.Time我应该在每个级别后更新它游戏的。我的应用程序是分布式的,所以我想确保我的所有应用程序不会同时更新它。这就是为什么我决定让它成为原子的。其实我很熟悉Golangsync/atomic包。我尝试使用atomic.LoadPointer()方法,但它需要不安全的特定参数类型。你还有其他办法吗?更新:好的,我这样解决了我的问题。我将时间变量定义为atomic.Value并使用原子加载和存储方法。这是代码:varmyTimeatomic.ValuemyTime.Sto

multithreading - App Engine Channel API 的线程安全/原子性

当我尝试使用GoogleAppEngine的ChannelAPI从两个或多个goroutines和/或任务队列发送消息时会发生什么?例如gochannel.Send(context,clientID,"Hello")gochannel.Send(context,clientID,"World")我知道在GAEGo中,所有goroutines都被多路复用到一个线程上。然而,这仍然允许在I/O期间进行抢占,并且channel发送可能符合I/O的条件。GAE开发服务器似乎序列化了所有请求,所以我没有看到任何channel发送重叠。生产服务器似乎允许一些请求并发,但channel发送看起来是原

java - couchbase golang json 原子增量

在其他couchbaseSDK中是否有类似于计数器的golangAPI可以帮助我们自动增加json文档中的某些字段?例如,我有一个下面的结构,其中有两个字段将与文档D1相关联typeCounterstruct{c1string`json:"c1"`c2string`json:"c2"`}对于传入的每个http请求,我想对c1和c2进行原子增量。因为它在一个json文档中,所以我无法使用GET并且不确定如何使用golang来使用计数器方法。 最佳答案 在文档中不可能有原子计数器,您有两种选择来解决这个问题:1)让您的文档引用单独的原子