并发编程的基本概念

并发编程的三个概念

  1. 原子性

    即一个操作要么全部执行,并且执行过程中不会被任何因素打断,要么就全部不执行。
    典型的例子就是银行转账,将A账户中的钱转入B账户。这个过程必须要保证原子性,否 则会导致数据不一致。

  2. 可见性

    可见性是用在多线程中的,指的是多个线程访问一个变量,其中一个线程修改了某个变量的值,那么其他线程可以立即看到修改的值。

  3. 有序性

    程序执行的顺序是按照代码的先后顺序来执行的。

    3.1 指令重排序

    public void testOrder() {
        int i = 1;//语句1
        int j = 2;//语句2
        int c = i + j;
    }
    

    (1)那么在这个例子中,语句1和语句2并无关联性。那么jvm在真正执行这段代码时,可能发生指令重排序。

    (2)一般来说,处理器为了提高程序运行效率,可能会对输入代码进行优化,它不保证程序中各个语句的执行先后顺序同代码中的顺序一致,但是它会保证程序最终执行结果和代码顺序执行的结果是一致的。

    (3)虽然指令重排序不会影响单线程的执行结果,但是在多线程中就会存在问题。

    private boolean inited = false;
    
    private void initContext() {}
    
    private void modifyContext() {}
    
    //线程1的代码
    public void testThrea1() {
        initContext();
        boolean inited = true;
    }
    
    //线程2的代码
    public void testThread2() {
        while(!inited) {
            Thread.sleep(1000);
        }
        
        modifyContext();
    }
    
posted @ 2017-09-25 20:27  jennyjj  阅读(146)  评论(0编辑  收藏  举报