Java 関数の同期ブロックは、同期ロックを取得することでスレッド セーフを実現し、スレッドが同期ブロックに入ることができなくなり、共有データへのアクセスが確実にスレッド セーフになります。具体的な手順: synchronized メソッドまたはコード ブロックを宣言し、synchronized キーワードを使用します。スレッドが同期ブロックに入ると、同期ロックを取得します。最初のスレッドが同期ロックを解放するまで、他のスレッドは同期ブロック内のデータにアクセスできません。同期ブロックには、同期する必要があるコードのみが含まれます。
#Java 関数の同期ブロックでスレッド セーフを実現するにはどうすればよいですか?
同期ブロックは、マルチスレッド環境で非スレッドセーフ関数をスレッドセーフにするために使用される糖衣構文です。これは本質的にミューテックス ロックであり、スレッドが同期ブロックに入ると同期ロックを取得し、そのスレッドがロックを解放するまで他のスレッドは同期ブロックに入ることができません。
構文
public synchronized void myFunc() { // 临界区代码 }
実践的なケース
非スレッドセーフ関数increment()があるとします。
、カウンター値に 1 を加算します。複数のスレッドが同時にこの関数を呼び出すと、カウンターの値が正しくなくなる可能性があります。この問題を解決するには、同期ブロックを使用します。
private int counter; public synchronized void increment() { counter++; }
この方法では、スレッドが increment()
関数を呼び出すと、スレッドは counter## の排他ロックを取得します。 #。最初のスレッドがロックを解放するまで、他のスレッドは
counter にアクセスできず、
counter へのアクセスがスレッドセーフであることが保証されます。
次の点に注意してください:
キーワードのみを使用して、クラスではなくメソッドまたはコード ブロックを同期できます。
以上がJava 関数の同期ブロックでスレッド セーフを実現するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。