ようこそ読書親指、一緒に交流を学ぶには、疑問を持って、メッセージを残してください。
オープンソースはGitHubの上でもありますJavaHouse、星歓迎
引用文
開発プロセスは、我々は、並行性の問題が発生したとき。どのように解決するには?
一つの解決策、シンプルで、粗:ロックされました。我々は、単一で一人だけを許可する、路肩に停車強大な力を与えるだろう。文字通り、並列プログラムは、シリアルプログラムになることです。現実はロック、南京錠や引き出しをロックし、というように。Javaでは、私たちは、キーワードとロックのインターフェイスを同期するロック。
synchronizedキーワード
同期、また、Javaキーワードで同期ロック、として知られています。また、JVM仮想マシンが関連付けられている同期原理を推測することができます。
同期ロックオブジェクト。ロックミューテックス(ミューテックスのロックを)監視のオペレーティングシステムに依存してロックモニター(モニター)のものと呼ばれるターゲットは、あります。ユーザーモードスレッドからオペレーティングシステムスイッチは、実際には、カーネルモードのプログラミング(二つの状態のCPUの)です。価格は、ビット高いので、同期ヘビー級の背後にあるロックとも偏っロック軽量ロックの導入です。
ロック(ロック監視モニタ)プロセス分析():
- 数が0にモニタに入力されると、Aスレッド
- あるモニター番号を入力1
- スレッドBは、モニターがブロックされます入力したいと思います。
スレッドはモニターを繰り返し入力することができ、それはリエントラントロックを同期して、同じのLock実装をロックしています。
- プログラムの検証
public class SynchronizedTest {
private static int i = 0;
public static void main(String[] args) {
test();
}
public static void test(){
synchronized (SynchronizedTest.class){
synchronized (SynchronizedTest.class){
i++;
}
}
}
}
- 結果は、実行
プログラムを適切に、エラーなし
この方法は、コードブロックは、上記の例の再進入ロックされ、コードブロックを変更して同期させることができます。
- 修正方法
public class SynchronizedTest {
static int n = 100;
final static CountDownLatch start = new CountDownLatch(n);
private static int i = 0;
public static void main(String[] args) throws InterruptedException {
for (int j = 0; j < n; j++) {
Thread thread = new Thread(new addNoSynchronized());
thread.start();
}
start.await();
System.out.println(i);
}
public static class addSynchronized implements Runnable{
@Override
public void run() {
addSynchronized();
}
public static synchronized void addSynchronized(){
for (int j = 0; j < 1000; j++) {
i++;
}
start.countDown();
}
}
}
- 業績
100000
あなたはsynchronizedキーワードを削除する場合は、スレッド不安ので、結果は高い確率100000ではない実行します。
ロックインタフェース
一般的に、我々はロックインタフェースを実現リエントラントロックReentrantLockのように、クラスを使用します。
- 使用
public class ReentranLockTest {
private static int j;
private static int n = 100;
private static CountDownLatch latch = new CountDownLatch(n);
public static void main(String[] args) throws InterruptedException {
for (int i = 0; i < n; i++) {
new Thread(new LockTest()).start();
}
latch.await();
System.out.println("结果为:"+j);
}
public static class LockTest implements Runnable{
static Lock lock = new ReentrantLock();
@Override
public void run() {
lockTest();
latch.countDown();
}
private void lockTest() {
lock.lock();
try {
for (int i = 0; i < 1000; i++) {
j++;
}
}finally {
lock.unlock();
}
}
}
}
- 業績
结果为:100000
ここでは、ロックが変更され、静的なキーワードである、J ++このリソース領域(パブリックリソース)をロックし、クラスオブジェクトである、それはクラスオブジェクトでない場合に何が起こるかを考えますか?チェーンロックである(図を参照)。
プログラムのためのキーでロックを解除できるの各スレッドは、ロック操作は意味がありません。私たちが必要とするのではロックです。