गो प्रोग्रामिंग भाषा में, bytes.Buffer
थ्रेड-सुरक्षित है? AFAIK, its documentation थ्रेड सुरक्षा का उल्लेख नहीं है।गो बाइट्स है। बफर थ्रेड-सुरक्षित?
8
A
उत्तर
17
सं
जाओ प्रलेखन एक सरल नियम इस प्रकार है: यदि यह नहीं स्पष्ट रूप से कहा है कि कुछ करने के लिए समवर्ती पहुँच सुरक्षित है, ऐसा नहीं है।
3
io.Pipe() फ़ंक्शन कॉल का उपयोग करें जो सिंक्रोनस पढ़ने/लिखने के लिए कनेक्टेड ऑब्जेक्ट्स (* पाइप रीडर, * पाइपवाइटर) की जोड़ी प्रदान करता है। यह समानांतर में किया जा सकता है, और यह एक थ्रेड-सुरक्षित है।
7
नहीं - लेकिन आप आसानी से इसे थ्रेड सुरक्षित संरचना में लपेट सकते हैं!
साधारण चीजें के लिए:
type Buffer struct {
b bytes.Buffer
m sync.Mutex
}
func (b *Buffer) Read(p []byte) (n int, err error) {
b.m.Lock()
defer b.m.Unlock()
return b.b.Read(p)
}
func (b *Buffer) Write(p []byte) (n int, err error) {
b.m.Lock()
defer b.m.Unlock()
return b.b.Write(p)
}
func (b *Buffer) String() string {
b.m.Lock()
defer b.m.Unlock()
return b.b.String()
}
..और यह सामान्य var buf Buffer
के रूप में उपयोग, आदि
bytes.Buffer की अधिक चाहते हैं? चेरी लेने के लिए स्वतंत्र महसूस करें:
func (b *Buffer) Bytes() []byte {
b.m.Lock()
defer b.m.Unlock()
return b.b.Bytes()
}
func (b *Buffer) Cap() int {
b.m.Lock()
defer b.m.Unlock()
return b.b.Cap()
}
func (b *Buffer) Grow(n int) {
b.m.Lock()
defer b.m.Unlock()
b.b.Grow(n)
}
func (b *Buffer) Len() int {
b.m.Lock()
defer b.m.Unlock()
return b.b.Len()
}
func (b *Buffer) Next(n int) []byte {
b.m.Lock()
defer b.m.Unlock()
return b.b.Next(n)
}
func (b *Buffer) ReadByte() (c byte, err error) {
b.m.Lock()
defer b.m.Unlock()
return b.b.ReadByte()
}
func (b *Buffer) ReadBytes(delim byte) (line []byte, err error) {
b.m.Lock()
defer b.m.Unlock()
return b.b.ReadBytes(delim)
}
func (b *Buffer) ReadFrom(r io.Reader) (n int64, err error) {
b.m.Lock()
defer b.m.Unlock()
return b.b.ReadFrom(r)
}
func (b *Buffer) ReadRune() (r rune, size int, err error) {
b.m.Lock()
defer b.m.Unlock()
return b.b.ReadRune()
}
func (b *Buffer) ReadString(delim byte) (line string, err error) {
b.m.Lock()
defer b.m.Unlock()
return b.b.ReadString(delim)
}
func (b *Buffer) Reset() {
b.m.Lock()
defer b.m.Unlock()
b.b.Reset()
}
func (b *Buffer) Truncate(n int) {
b.m.Lock()
defer b.m.Unlock()
b.b.Truncate(n)
}
func (b *Buffer) UnreadByte() error {
b.m.Lock()
defer b.m.Unlock()
return b.b.UnreadByte()
}
func (b *Buffer) UnreadRune() error {
b.m.Lock()
defer b.m.Unlock()
return b.b.UnreadRune()
}
func (b *Buffer) WriteByte(c byte) error {
b.m.Lock()
defer b.m.Unlock()
return b.b.WriteByte(c)
}
func (b *Buffer) WriteRune(r rune) (n int, err error) {
b.m.Lock()
defer b.m.Unlock()
return b.b.WriteRune(r)
}
func (b *Buffer) WriteString(s string) (n int, err error) {
b.m.Lock()
defer b.m.Unlock()
return b.b.WriteString(s)
}
func (b *Buffer) WriteTo(w io.Writer) (n int64, err error) {
b.m.Lock()
defer b.m.Unlock()
return b.b.WriteTo(w)
}
+0
rwmux का उपयोग करना चाहिए – xiaoyi
संबंधित मुद्दे
बस उत्सुक है, क्या वह नियम कहीं दस्तावेज है? – Ztyx