1 /** 2 * 多个线程之间共享数据的方式探讨 3 * @author LiTaiQing 4 * 5 * ************************************************* 6 * 如果每个线程执行的代码不同,这时候需要用不同的Runnable对象,有 7 * 如下两种方式来实现这些Runnble对象之间的数据共享: 8 * 1.将共享数据封装在另外一个对象中,然后将这个对象逐一传递给 9 * 各个Runnble对象。每个线程对共享数据的操作方法也分配到那个对象身 10 * 上去完成,这样容易实现针对该数据进行的各个操作的互斥和通信。 11 * 2.将这些Runnable对象作为某一个类中的内部类,共享数据作为 12 * 这个外部类中的成员变量,每个线程对共享数据的操作方法也分配给外部类, 13 * 以便实现对共享数据进行的各个操作的互斥和通信,作为内部类的各个Runnble 14 * 对象调用外部类的这些方法。 15 * 上面两种方式的组合:将共享数据封装在另一个对象中,每个线程对 16 * 共享数据的操作方法也分配到那个对象身上去完成,对象作为这个外部类中的 17 * 成员变量或方法中的局部变量,每个线程的Runnable对象作为外部类中的 18 * 成员内部类或局部内部类。 19 * 总之,要同步互斥的极短代码最好是分别放在几个独立的方法中,这些 20 * 方法再放在同一个类中,这样比较容易实现它们之间的同步互斥和通信。 21 * ************************************************* 22 * 23 */ 24 public class MultiThreadShareData { 25 26 private static ShareData1 data1 = new ShareData1(); 27 28 public static void main(String[] args) { 29 30 final ShareData1 data2 = new ShareData1(); 31 new Thread(new MyRunnable1(data1)).start(); 32 new Thread(new MyRunnable1(data2)).start(); 33 34 final ShareData1 data1 = new ShareData1(); 35 new Thread(new Runnable(){ 36 @Override 37 public void run() { 38 data1.decrement(); 39 } 40 }).start(); 41 new Thread(new Runnable(){ 42 @Override 43 public void run() { 44 data1.increment(); 45 } 46 }).start(); 47 } 48 49 50 } 51 52 class MyRunnable1 implements Runnable{ 53 54 private ShareData1 data1; 55 56 public MyRunnable1(ShareData1 data1){ 57 this.data1 = data1; 58 } 59 60 @Override 61 public void run() { 62 data1.decrement(); 63 } 64 } 65 66 class MyRunnable2 implements Runnable{ 67 68 private ShareData1 data1; 69 70 public MyRunnable2(ShareData1 data1){ 71 this.data1 = data1; 72 } 73 74 @Override 75 public void run() { 76 data1.increment(); 77 } 78 } 79 80 class ShareData1 /*implements Runnable*/{ 81 82 private int count = 100; 83 84 private int j = 0; 85 public synchronized void increment(){ 86 j++; 87 } 88 public synchronized void decrement(){ 89 j--; 90 } 91 // @Override 92 // public void run() { 93 // while(true){ 94 // count--; 95 // } 96 // } 97 98 }