Java多线程与并发应用-(6)-多个线程之间共享对象和数据的方式
2015-04-23 23:41
776 查看
此内容来自张孝祥老师的java多线程与并发库高级应用
如果多个线程执行的代码相同,可以使用同一个Runnable对象,这个Runnable对象中有那个共享数据。
如果多个线程执行的代码不同,这时候需要用不同的Runnable对象。将共享对象封装在另一个对象中,然后将这个对象逐一传给各个Runnable对象。每个线程对共享数据的操作方法也分配到那个对象身上去完成,这样容易实现针对该对象进行各个操作的互斥和通信。
总之,要同步互斥的几段代码最好分别放在几个独立的方法中,这些方法再放在同一个类型,将这个类的实例交给Runnable处理,这样容易实现他们之间的同步互斥和通信
实现代码:
如果多个线程执行的代码相同,可以使用同一个Runnable对象,这个Runnable对象中有那个共享数据。
如果多个线程执行的代码不同,这时候需要用不同的Runnable对象。将共享对象封装在另一个对象中,然后将这个对象逐一传给各个Runnable对象。每个线程对共享数据的操作方法也分配到那个对象身上去完成,这样容易实现针对该对象进行各个操作的互斥和通信。
总之,要同步互斥的几段代码最好分别放在几个独立的方法中,这些方法再放在同一个类型,将这个类的实例交给Runnable处理,这样容易实现他们之间的同步互斥和通信
实现代码:
public class Demo2 { /** * @param args */ public static void main(String[] args) { MyAddRun addRun=new MyAddRun(); MySubRun subRun=new MySubRun(); new Thread(addRun,"add--1111----- ").start(); new Thread(addRun,"add--2222----- ").start(); new Thread(subRun,"sub--3333----- ").start(); new Thread(subRun,"sub--4444----- ").start(); } }
class Calculate { private static int i; public static synchronized void addOne() { i++; System.out.println(Thread.currentThread().getName()+ i); } public static synchronized void subOne() { i--; System.out.println(Thread.currentThread().getName()+ i); } }
class MyAddRun implements Runnable { @Override public void run() { for(int j=0;j<100;j++) { Calculate.addOne(); } } }
class MySubRun implements Runnable { @Override public void run() { for(int j=0;j<100;j++) { Calculate.subOne(); } } }
相关文章推荐
- java多线程并发库高级应用 之 多个线程之间共享数据的方式探讨
- java多线程与线程并发五:多个线程访问共享对象和数据的方式
- 多线程并发库高级应用 之 多个线程之间共享数据的方式探讨
- 多线程并发库高级应用 之 多个线程之间共享数据的方式探讨
- 【Java多线程与并发库】7.多个线程之间共享数据的方式探讨
- 【Java多线程与并发库】7.多个线程之间共享数据的方式探讨
- 【Java多线程与并发库】06 多个线程之间共享数据的方式探讨
- java多线程之多个线程访问共享对象和数据的方式
- Java高并发编程:多个线程之间共享数据的方式探讨
- java多线程学习-多个线程访问对象共享数据的方式
- java并发-多线程之多个线程之间共享数据(6)
- 多线程和并发库应用五-线程间数据共享
- 多线程和并发库应用七-线程间数据共享2
- Java线程与并发库高级应用-线程范围内共享数据ThreadLocal类
- java并发编程之:线程共享数据的方式
- Java多个线程之间处理共享数据的方式
- JAVA 并发编程-多个线程之间共享数据(六)
- 【转】JAVA 并发编程-多个线程之间共享数据
- java多线程与线程并发四:线程范围内的共享数据
- Java多线程与并发库高级应用之线程数据交换Exchanger