AtomicBoolean运用

介绍:
在这个Boolean的值变化的时候不允许在之间插入其他操作,保持操作的原子性.
方法和举例
compareAndSet(boolean expect, boolean update)
这个方法主要两个作用

  • 1.比较AtomicBoolean和expect的值,如果一致,执行方法内的语句。其实就是一个if语句
  • 2.把AtomicBoolean的值设成update

比较最要的是这两件事是一气呵成的,这两个个动作之间不会被打断,任何内部或者外部的语句都不可能在两个动作之间运行。为多线程的控制提供了解决的方案。

首先先看如下例子
Java代码

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
private static class BarWorker implements Runnable {  
  
 private static boolean exists = false;  
  
 private String name;  
  
 public BarWorker(String name) {  
  this.name = name;  
 }  
  
 public void run() {  
  if (!exists) {  
   exists = true;  
   System.out.println(name + " enter");  
   System.out.println(name + " working");  
   System.out.println(name + " leave");  
   exists = false;  
  } else {  
   System.out.println(name + " give up");  
  }  
 }   
  
}

static变量exists用来实现同一时间只有一个worker在工作. 但是假设exists的判断和exists = true;之间有了
其他指令呢
Java代码

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
private static class BarWorker implements Runnable {  
  
 private static boolean exists = false;  
  
 private String name;  
  
 public BarWorker(String name) {  
  this.name = name;  
 }  
  
 public void run() {  
  if (!exists) {  
   try {  
    TimeUnit.SECONDS.sleep(1);  
   } catch (InterruptedException e1) {  
    // do nothing  
   }  
   exists = true;  
   System.out.println(name + " enter");  
   try {  
    System.out.println(name + " working");  
    TimeUnit.SECONDS.sleep(2);  
   } catch (InterruptedException e) {  
    // do nothing  
   }  
   System.out.println(name + " leave");  
   exists = false;  
  } else {  
   System.out.println(name + " give up");  
  }  
 }  
  
}

这时输出是
bar2 enter
bar2 working
bar1 enter
bar1 working
bar1 leave
bar2 leave
看到两个线程同时工作了.
这时可以用AtomicBoolean
Java代码

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
private static class BarWorker implements Runnable {  
  
  private static AtomicBoolean exists = new AtomicBoolean(false);  
  
  private String name;  
  
  public BarWorker(String name) {  
   this.name = name;  
  }  
  
  public void run() {  
   if (exists.compareAndSet(false, true)) {  
    System.out.println(name + " enter");  
    try {  
     System.out.println(name + " working");  
     TimeUnit.SECONDS.sleep(2);  
    } catch (InterruptedException e) {  
     // do nothing  
    }  
    System.out.println(name + " leave");  
    exists.set(false);  
   }else{  
    System.out.println(name + " give up");  
   }  
  }  
  
 }

因为它提供了原子性操作,其中exists.compareAndSet(false, true)这个操作把比较和赋值操作组成了一个原子操作,
中间不会提供可乘之机.输出为
bar1 enter
bar1 working
bar2 give up

当前网速较慢或者你使用的浏览器不支持博客特定功能,请尝试刷新或换用Chrome、Firefox等现代浏览器