对于以下代码:
阅读器.go
func (r *Reader) ReadData(objCh chan *data.InputEntry, stopCh chan struct{}) {
var object data.InputEntry
go func() {
for {
....
jsonErr := json.Unmarshal(byteBuffer[:n], &object) // Line 55
...
objCh <- &object
}
}()
}
作家.go
func (w *Processor) ProcessData(objectCh chan *data.InputEntry, stopCh chan struct{}) {
go func() {
for {
object, wd := <-objectCh
...
w.Log.Printf("Received object: %v\n", object) // Line 83
}
}()
}
以下是错误:
WARNING: DATA RACE
Write at 0x00c000138000 by goroutine 7:
reflect.Value.SetString()
/usr/local/go/src/reflect/value.go:1712 +0xb3
encoding/json.(*decodeState).literalStore()
/usr/local/go/src/encoding/json/decode.go:972 +0x3179
encoding/json.(*decodeState).value()
/usr/local/go/src/encoding/json/decode.go:401 +0x2dc
encoding/json.(*decodeState).object()
/usr/local/go/src/encoding/json/decode.go:782 +0x225e
encoding/json.(*decodeState).value()
/usr/local/go/src/encoding/json/decode.go:387 +0xaf
encoding/json.(*decodeState).unmarshal()
/usr/local/go/src/encoding/json/decode.go:180 +0x27a
encoding/json.Unmarshal()
/usr/local/go/src/encoding/json/decode.go:107 +0x1de
github.com/myhub/code/reader.(*Reader).ReadData.func1()
/home/../code/src/github.com/myhub/code/reader/reader.go:55 +0x385
Previous read at 0x00c000138000 by goroutine 8:
reflect.typedmemmove()
/usr/local/go/src/runtime/mbarrier.go:177 +0x0
reflect.packEface()
/usr/local/go/src/reflect/value.go:119 +0x126
reflect.valueInterface()
/usr/local/go/src/reflect/value.go:1023 +0x1b9
reflect.Value.Interface()
/usr/local/go/src/reflect/value.go:993 +0x3c27
fmt.(*pp).printValue()
reader.go第 55( ) 行和第 83( writer.go)行之间的数据竞争
如何解决此错误?
倚天杖
相关分类