多个线程之间共享数据的方式探讨

例子:卖票:多个窗口同时卖这100张票,票就需要多个线程共享

a、如果每个线程执行的代码相同,可以使用同一个Runnable对象,这个对象中有共享数据。

卖票就可以这样做,每个窗口都在做卖票任务,卖的票都是同一个数据。

b、如果每个线程执行的代码不同,就需要使用不同的Runnable对象,有两种方式实现

具体代码如下:

package tradition;

/**
 * 多个线程间共享数据
 */
public class MultiThreadShareData {
	
	private static ShareData1 data1 = new ShareData1();

	public static void main(String[] args) {
		final ShareData1 data2 = new ShareData1();
		new Thread(new MyRunnable1(data2)).start();
		new Thread(new MyRunnable2(data2)).start();
		
		final ShareData1 data1 = new ShareData1();
		new Thread(new Runnable() {

			@Override
			public void run() {
				data1.decrement();
			}
			
		}).start();
		new Thread(new Runnable() {

			@Override
			public void run() {
				data1.increment();
			}
			
		}).start();
	}

}

class MyRunnable1 implements Runnable{
	
	private ShareData1 data1;
	
	public MyRunnable1(ShareData1 data1) {
		this.data1 = data1;
	}
	
	@Override
	public void run() {
		data1.decrement();
	}
}

class MyRunnable2 implements Runnable{
	
	private ShareData1 data1;
	
	public MyRunnable2(ShareData1 data1) {
		this.data1 = data1;
	}
	
	@Override
	public void run() {
		data1.increment();
	}
}

class ShareData1{
	private int j = 0;
	
	public synchronized void increment(){
		j ++;
	}
	
	public synchronized void decrement(){
		j --;
	}

}
注意:上述方法实现了同步。


Runnable对象之间的数据共享:
a)将共享数据单独封装到一个对象中,同时在对象中提供操作这些共享数据的方法,可以方便实现对共享数据各项操作的互斥和通信。
b)将各个Runnable对象作为某个类的内部类,共享数据作为外部类的成员变量,对共享数据的操作方法也在外部类中提供,以便实现互斥和通信,内部类的Runnable对象调用外部类中操作共享数据的方法即可。
注意:要同步互斥的几段代码最好分别放在几个独立的方法中,这些方法再放在同一个类中,这样比较容易实现它们之间的同步互斥和通信。


参考视频:《Java多线程与并发库高级应用》

你可能感兴趣的:(Java多线程与高并发库,Java并发编程)