首页 > 编程语言 > 详细

Java高并发之同步异步

时间:2019-01-10 16:18:16      阅读:169      评论:0      收藏:0      [点我收藏+]

1、概念理解:

技术分享图片

2、同步的解决方案:

1).基于代码

synchronized 关键字

 修饰普通方法:作用于当前实例加锁,进入同步代码前要获得当前实例的锁。

 修饰静态方法:作用于当前类对象加锁,进入同步代码前要获得当前类对象的锁。

    修饰代码块:指定加锁对象,对给定对象加锁,进入同步代码块前要获得给定对象的锁。

 code1

技术分享图片
package com.thread;

import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;

/**
 * 同步方法
 * @author Administrator
 *
 */
public class SynchronizedMethod implements Runnable{

    //静态共享变量 i
    static int i = 0;
    
    /**
     * 自增
     */
    public synchronized void increase(){
        i++;
    }
    
    @Override
    public void run() {
        for (int j = 0; j < 100; j++) {
            increase();
        }
    }
    
    public static void main(String[] args) throws InterruptedException {
        SynchronizedMethod instance = new SynchronizedMethod();
        ExecutorService executorService = Executors.newFixedThreadPool(2);
        for (int i = 0; i < 3; i++) {
            //同一实例,线程共享静态变量i
//            executorService.execute(instance);
            //不同实例,线程单独享有变量i,达不到同步目的
            executorService.execute(new SynchronizedMethod());
            /**
             * 由于线程执行时间过短,在不同实例下,可能会得到类似于同步的结果。
             */
            Thread.sleep(100);
        }
        
        executorService.shutdown();
        
        System.out.println(i);  //300
        
    }
}
View Code

code2

技术分享图片
package com.thread;

import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;

/**
 * 同步代码块
 * @author Administrator
 *
 */
public class SynchronizedCodeBlock implements Runnable{

    //静态共享变量 i
    static int i = 0;
    
    @Override
    public void run() {
        //同步进来的对象
        synchronized(this){  //SynchronizedCodeBlock.class
            for (int j = 0; j < 100; j++) {
                i++;
            }
        }
    }
    
    public static void main(String[] args) throws InterruptedException {
        SynchronizedCodeBlock instance = new SynchronizedCodeBlock();
        ExecutorService executorService = Executors.newFixedThreadPool(2);
        for (int i = 0; i < 3; i++) {
//            executorService.execute(instance);
            executorService.execute(new SynchronizedCodeBlock());
            Thread.sleep(10);
        }
        
        executorService.shutdown();
        
        System.out.println(i);  //300
        
    }
}
View Code

 

 参考博客:

https://blog.csdn.net/javazejian/article/details/72828483

 

 

2).基于数据库

 

Java高并发之同步异步

原文:https://www.cnblogs.com/x-jingxin/p/10250482.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!