JVMJava 杂谈

多线程高并发以及锁竞争

2017-11-28  本文已影响96人  编程界的小学生

一、线程安全概念
当多个线程访问某一个类(对象或方法)时,这个类始终都能表现出正确的行为,那么这个类(对象或方法)就是线程安全的。

二、多线程并发Demo


/**
 * @author chentongwei@bshf360.com 2017-11-27 18:11
 */
public class MyThread extends Thread {

    private int count = 5;

    @Override
    public void run() {
        count --;
        System.out.println(this.currentThread().getName() + " count = " + count);
    }

    public static void main(String[] args) {
        MyThread myThread = new MyThread();
        Thread t1 = new Thread(myThread, "t1");
        Thread t2 = new Thread(myThread, "t2");
        Thread t3 = new Thread(myThread, "t3");
        Thread t4 = new Thread(myThread, "t4");
        Thread t5 = new Thread(myThread, "t5");
        t1.start();
        t2.start();
        t3.start();
        t4.start();
        t5.start();
    }
}

输出结果:

t2 count = 3
t1 count = 2
t5 count = 0
t3 count = 3
t4 count = 1

很明显的发现我们想要4,3,2,1,0;现在整个3,3,2,1,0;很明显不对,出现并发了。

为什么呢?

当多个线程访问myThread的run方法时,以排队的方式进行处理(这里排队是按照CPU分配的先后顺序而定的),一个线程想要执行synchronized修饰的方法里的代码。首先是尝试获取锁,若拿到锁,执行synchronized代码体内容;拿不到锁,这个线程就会不断地尝试获得这把锁,直到拿到为止,而且是多个线程同时去竞争这把锁(这就是锁竞争)。

如何解决?
给run方法上锁(synchronized)

三、什么是锁竞争?

image.png

若有兴趣,欢迎来加入群,【Java初学者学习交流群】:458430385,此群有Java开发人员、UI设计人员和前端工程师。有问必答,共同探讨学习,一起进步!
欢迎关注我的微信公众号【Java码农社区】,会定时推送各种干货:


qrcode_for_gh_577b64e73701_258.jpg
上一篇下一篇

猜你喜欢

热点阅读