在Golang中,可以使用sync.Mutex或sync.RWMutex来实现多线程安全的日志写入。这里是一个简单的示例,展示了如何使用sync.Mutex实现多线程安全的日志写入:
package main
import (
"fmt"
"log"
"os"
"sync"
"time"
)
type Logger struct {
mu sync.Mutex
logger *log.Logger
}
func NewLogger() *Logger {
return &Logger{
logger: log.New(os.Stdout, "", log.LstdFlags),
}
}
func (l *Logger) Log(message string) {
l.mu.Lock()
defer l.mu.Unlock()
l.logger.Println(message)
}
func main() {
logger := NewLogger()
var wg sync.WaitGroup
for i := 0; i < 10; i++ {
wg.Add(1)
go func(i int) {
defer wg.Done()
logger.Log(fmt.Sprintf("Log message %d from goroutine %d", i, i))
}(i)
}
wg.Wait()
}
在这个示例中,我们创建了一个Logger结构体,它包含一个sync.Mutex和一个log.Logger。Log方法使用互斥锁来确保在同一时间只有一个goroutine可以访问log.Logger实例。这样,我们就可以在多个goroutine中安全地写入日志。
注意:在实际应用中,你可能需要根据需求调整日志级别、格式等设置。此外,还可以考虑使用第三方日志库,如logrus或zap,它们通常已经实现了多线程安全的日志写入。