Procházet zdrojové kódy

feat: CompareAndSwapInt32 may be better than AddInt32 (#2077)

wxc před 2 roky
rodič
revize
d200ba4a7b
1 změnil soubory, kde provedl 2 přidání a 4 odebrání
  1. 2 4
      core/mr/mapreduce.go

+ 2 - 4
core/mr/mapreduce.go

@@ -376,9 +376,7 @@ type onceChan struct {
 }
 
 func (oc *onceChan) write(val interface{}) {
-	if atomic.AddInt32(&oc.wrote, 1) > 1 {
-		return
+	if atomic.CompareAndSwapInt32(&oc.wrote, 0, 1) {
+		oc.channel <- val
 	}
-
-	oc.channel <- val
 }