1.线程范围内共享变量 1.1 前奏: 使用一个Map来实现线程范围内共享变量 public class ThreadScopeShareData { static Map<Thread, Integer> dataMap = new HashMap<Thread, Integer>(); public static void main(String[] args) { for (int i = 0; i < 2; i++) { new Thread(new Runnable
一.每个线程执行的代码相同: 若每个线程执行的代码相同,共享数据就比较方便.可以使用同一个Runnable对象,这个Runnable对象中就有那个共享数据. public class MultiThreadShareData { public static void main(String[] args) { SaleTickets sale = new SaleTickets(); new Thread(sale).start(); new Thread(sale).start(); } }
本例定义了4个类,这里说一下,方便下面讲解.分别是Product(产品),Producer(生产者),Consumer(消费者), Test(测试类). 多线程之间通信与共享数据只要引用同一内存区域就可以了,做法就是new一个对象,传多个引用. Product pro = new Product(); Producer producer = new Producer(pro); Consumer consumer = new Consumer(pro); 但是由于cpu的随机性,共享数据时容易出