ホームページ  >  記事  >  Java  >  Java のいくつかの一般的なロック

Java のいくつかの一般的なロック

王林
王林オリジナル
2019-11-13 17:16:443668ブラウズ

Java のいくつかの一般的なロック

1. スピン ロック

名前が示すように、スピン ロックは一定時間 (スピン) 待機し、何も待機しません。この間にアクセスが発生します。それを行わない場合は、リソースが解放されるのを待つだけで済みます。利点は、カーネル モードとユーザー モードの切り替えによる効率の低下がないことです。ただし、アクセスできない場合は、リソースを使用すると、CPU リソースを占有し続けるため、一定期間循環し、その後ブロッキング状態になります。

2. 重量ロック

synchronized は重量ロックの実装メカニズムであり、リソースを取得できないプロセスはブロック状態になります。

3. バイアス ロック

名前が示すように、最初のプロセスがリソースにアクセスするようにバイアスします。1 つのプロセスのみが同期コード ブロックを実行する場合、最後のロックはバイアス ロックになります。他のスレッドがリソースを占有する場合、軽量ロックにアップグレードされます。

4. 軽量ロック

バイアスされたロックがアップグレードされると、軽量ロックになります。ロックはアップグレードのみ可能で、ダウングレードはできません。軽量ロック内の他のプロセスは自己選択状態に入りますが、自己選択が失敗すると、重量ロックがアップグレードされます。

5. 公平なロックと不公平なロック

主に、スレッドが先着順でロックを取得するかどうかを指します。不公平まで設定でき、公平に設定できます。

6. 悲観的ロック

常に最悪のシナリオを想定します。データを取得するたびに、他の人がそれを変更するだろうと考え、データを取得するたびに常にロックされているため、他の誰かがデータを取得しようとしても、ロックを取得するまでブロックされます (共有リソースは一度に 1 つのスレッドによってのみ使用され、他のスレッドはブロックされ、リソースは使用後は他のスレッドに転送されます)。

従来のリレーショナル データベースでは、行ロック、テーブル ロック、読み取りロック、書き込みロックなどの多くのロック メカニズムが使用されており、これらはすべて操作前にロックされます。 Java の synchronized ロックや ReentrantLock などの排他的ロックは、悲観的ロックの考え方を実装したものです。

7. 楽観的ロック

常に最良の状況を想定します。データを取得しに行くたびに、他の人がそのデータを変更しないだろうと考えます。ただし、更新時には、この期間中に他の人がデータを更新したかどうかが判断されます。これは、(データベース内の) バージョン番号メカニズムと CAS アルゴリズムを使用して実装できます。

推奨チュートリアル: Java チュートリアル

以上がJava のいくつかの一般的なロックの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。