Java、多线程处理

        编写一段代码,启动1000个线程。每个线程给初始值为0的变量sum加1。定义一个Integer包装对象来保存sum。使用同步和不使用同步来运行这个程序。


package pack2;

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

public class Test{
	public static void main(String[] args) {
           //使用Executors的静态方法创建一个可自动创建新线程的线程池并赋值
		ExecutorService exService = Executors.newCachedThreadPool();
		Sum sum = new Sum();
	
		for (int i = 0; i < 1000; i++) //创建1000个线程
			exService.execute(()->sum.add(1));    //使用Lamda表达式调用add()方法
	
		exService.shutdown();    //关闭线程池(会先执行完所有线程)
		System.out.println("Sum is "+sum.getSum());
	}

    //静态内部类
	private static class Sum{
		private Integer sum = 0;//对象,需先赋值为0
	
        //同步实例方法(锁为对象)
		public synchronized void add(int value) {
			sum += value;
		}
    
		public Integer getSum() {
			return sum;
		}
	}
	
}

        


Java、多线程处理

 

上一篇:【并发编程】--- 线程池七大参数+四种拒绝策略 + 如何合理配置线程数等简介


下一篇:Java线程池 Executors