java并发编程

一 并发三要素:

1 原子性

   synchronize,可修饰方法或块

   ReentrantLock,同步锁,例如 Lock lock = new ReentrantLock();   lock.lock(); lock.unlock();

2 可见性,也称一致性

  2.1 volatile,禁止cpu指令重排序,java工作内存(本地线程所占用空间)将共享变量的值立即写到主存;

  2.2 volatile无法保证原则性


3 有序性

 满足1和2,一般就满足了有序性。

happens-before 八大原则----------深入理解jvm

  • 程序次序规则:一个线程内,按照代码顺序,书写在前面的操作先行发生于书写在后面的操作
  • 锁定规则:一个unLock操作先行发生于后面对同一个锁额lock操作
  • volatile变量规则:对一个变量的写操作先行发生于后面对这个变量的读操作
  • 传递规则:如果操作A先行发生于操作B,而操作B又先行发生于操作C,则可以得出操作A先行发生于操作C
  • 线程启动规则:Thread对象的start()方法先行发生于此线程的每个一个动作
  • 线程中断规则:对线程interrupt()方法的调用先行发生于被中断线程的代码检测到中断事件的发生
  • 线程终结规则:线程中所有的操作都先行发生于线程的终止检测,我们可以通过Thread.join()方法结束、Thread.isAlive()的返回值手段检测到线程已经终止执行
  • 对象终结规则:一个对象的初始化完成先行发生于他的finalize()方法的开始
4 实例

采用synchronized:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
public class Test {
     public  int inc = 0 ;
 
     public synchronized void increase() {
         inc++;
     }
 
     public static void main(String[] args) {
         final Test test = new Test();
         for ( int i= 0 ;i< 10 ;i++){
             new Thread(){
                 public void run() {
                     for ( int j= 0 ;j< 1000 ;j++)
                         test.increase();
                 };
             }.start();
         }
 
         while (Thread.activeCount()> 1 //保证前面的线程都执行完
             Thread.yield();
         System.out.println(test.inc);
     }
}

采用Lock:

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
public class Test {
     public  int inc = 0 ;
     Lock lock = new ReentrantLock();
 
     public  void increase() {
         lock.lock();
         try {
             inc++;
         } finally {
             lock.unlock();
         }
     }
 
     public static void main(String[] args) {
         final Test test = new Test();
         for ( int i= 0 ;i< 10 ;i++){
             new Thread(){
                 public void run() {
                     for ( int j= 0 ;j< 1000 ;j++)
                         test.increase();
                 };
             }.start();
         }
 
         while (Thread.activeCount()> 1 //保证前面的线程都执行完
             Thread.yield();
         System.out.println(test.inc);
     }
}

采用AtomicInteger:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
public class Test {
     public  AtomicInteger inc = new AtomicInteger();
 
     public  void increase() {
         inc.getAndIncrement();
     }
 
     public static void main(String[] args) {
         final Test test = new Test();
         for ( int i= 0 ;i< 10 ;i++){
             new Thread(){
                 public void run() {
                     for ( int j= 0 ;j< 1000 ;j++)
                         test.increase();
                 };
             }.start();
         }
 
         while (Thread.activeCount()> 1 //保证前面的线程都执行完
             Thread.yield();
         System.out.println(test.inc);
     }
}
在java 1.5的java.util.concurrent.atomic包下提供了一些原子操作类,即对基本数据类型的 自增(加1操作),自减(减1操作)、以及加法操作(加一个数),减法操作(减一个数)进行了封装,保证这些操作是原子性操作。atomic是利用CAS来实现原子性操作的(Compare And Swap),CAS实际上是利用处理器提供的CMPXCHG指令实现的,而处理器执行CMPXCHG指令是一个原子性操作。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

步基

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值