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
publicclass Test {
    public int inc = 0;
 
    publicsynchronized void increase() {
        inc++;
    }
 
    publicstatic void main(String[] args) {
        finalTest test = newTest();
        for(inti=0;i<10;i++){
            newThread(){
                publicvoid run() {
                    for(intj=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
publicclass Test {
    public int inc = 0;
    Lock lock = newReentrantLock();
 
    public void increase() {
        lock.lock();
        try{
            inc++;
        }finally{
            lock.unlock();
        }
    }
 
    publicstatic void main(String[] args) {
        finalTest test = newTest();
        for(inti=0;i<10;i++){
            newThread(){
                publicvoid run() {
                    for(intj=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
publicclass Test {
    public AtomicInteger inc = newAtomicInteger();
 
    public void increase() {
        inc.getAndIncrement();
    }
 
    publicstatic void main(String[] args) {
        finalTest test = newTest();
        for(inti=0;i<10;i++){
            newThread(){
                publicvoid run() {
                    for(intj=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指令是一个原子性操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

步基

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

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

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

打赏作者

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

抵扣说明:

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

余额充值