Java では、開発者は synchronized キーワードを利用して、いつでも単一のスレッドだけが特定のコード ブロックを実行できるようにします。時間。ただし、この概念は Go のプログラミング パラダイムに直接変換されるわけではありません。
Go は、「通信によってメモリを共有する。メモリの共有によって通信しない」という原則を採用しています。 Go では、共有変数を直接変更してアクセスする代わりに、チャネルなどのメカニズムを使用してゴルーチン (並行関数) 間でデータを渡すことを開発者に推奨しています。このアプローチは、データの破損や競合状態を防ぐのに役立ちます。
特定のシナリオでは、変数への同時アクセスを保護するためにミューテックスの使用が必要になる場合があります。ミューテックス (相互排他) により、常に 1 つのゴルーチンだけがコードの特定のセクションにアクセスできるようになります。次に、ミューテックスを使用する例を示します。
var ( mu sync.Mutex protectMe int ) // Accessing and modifying protectMe func getMe() int { mu.Lock() me := protectMe mu.Unlock() return me } func setMe(me int) { mu.Lock() protectMe = me mu.Unlock() }
開発者は可能な限り、共有メモリよりも通信を優先する必要があります。チャネルを使用すると、ゴルーチンがデータを安全に送受信できるようになり、変数の同期の複雑さを回避できます。次のアプローチを検討してください。
// channel for communicating state updates var stateChan = make(chan int) func setMe(me int) { stateChan <- me } func getMe() { return <-stateChan }
同期手法を使用すると、パフォーマンスのオーバーヘッドが発生する可能性があります。アトミック操作は、ロックせずにメモリ上で直接操作するため、通常、ミューテックスよりも高速です。ただし、ミューテックスは柔軟性が高く、複雑なデータ構造を保護するために使用できます。
変数を保護および同期する方法を理解することは、同時実行 Go プログラムを作成する場合に非常に重要です。ミューテックスは変数を直接保護しますが、Go は通信ベースのアプローチを推奨します。チャネルやその他の通信メカニズムを利用することで、開発者はデータの一貫性の問題を引き起こすことなく、高度に同時実行性と拡張性のあるシステムを作成できます。
以上がGo で変数への同時アクセスを同期するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。