应付面试:面试管一般会问有过线程没有,你会在A的线程里面获取B线程的数据吗?
见图:(图1)
1.创建一个缓存池,用于线程管理
package test20140907.testthread3; import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; import java.util.concurrent.Future; public class ThreadPool { private ThreadPool() { } private static ThreadPool instance; public static ThreadPool getInstance() { if (instance == null) { instance = new ThreadPool(); } return instance; } @SuppressWarnings("rawtypes") static Future future =null; static ExecutorService cachedService; public void init() { cachedService = Executors.newFixedThreadPool(1); cachedService.execute(new RunableA()); } class RunableA implements Runnable { @Override public void run() { TaskFirst tf =new TaskFirst(); tf.getValue(); } } }
2.任务下发
package test20140907.testthread3; import java.util.concurrent.TimeUnit; import java.util.concurrent.locks.Condition; import java.util.concurrent.locks.Lock; import java.util.concurrent.locks.ReentrantLock; public class TaskFirst { static double d; Lock sendlock = new ReentrantLock(); Condition sendlockCondition =sendlock.newCondition(); public void addValue(double doub){ sendlock.lock(); try { sendlockCondition.await(5,TimeUnit.SECONDS); } catch (InterruptedException e) { e.printStackTrace(); } System.out.println("getValue d: "+ d); sendlock.unlock(); } public void getValue(){ sendlock.lock(); try { Thread.sleep(3000); } catch (InterruptedException e) { e.printStackTrace(); } this.d= 5.5; System.out.println("addValue d: "+ d); sendlockCondition.signal(); sendlock.unlock(); } }
3.测试 模拟一个执行任务的线程获取数据,该线程犹如网络延迟耗费3s 然后接收任务的线程等待5s 获取数据 完成一次同步的通讯
package test20140907.testthread3; public class Test { public static void main(String[] args) { ThreadPool.getInstance().init(); TaskFirst tf =new TaskFirst(); tf.addValue(2); } }
捐助开发者
在兴趣的驱动下,写一个免费
的东西,有欣喜,也还有汗水,希望你喜欢我的作品,同时也能支持一下。 当然,有钱捧个钱场(右上角的爱心标志,支持支付宝和PayPal捐助),没钱捧个人场,谢谢各位。
谢谢您的赞助,我会做的更好!
相关推荐
javasynchronized详解.pdf
Javasynchronized机制.pdf
Java语言提供了专门机制以解决这种冲突,有效避免了同一个数据对象被多个线程同时访问。 需要明确的几个问题: synchronized关键字可以作为函数的修饰符,也可作为函数内的语句,也就是平时说的同步方法和同步语句...
本篇文章是对Synchronized和java.util.concurrent.locks.Lock的区别进行了详细的分析介绍,需要的朋友参考下
Java-synchronized详解.docx
基础理论知识,描述lock和synchronized的区别和基础的理论,其中还有死锁等基础概念。
java里面synchronized用法
java锁机制Synchronized参考.pdf
本文档主要讲述的是java synchronized详解;Java语言的关键字,当它用来修饰一个方法或者一个代码块的时候,能够保证在同一时刻最多只有一个线程执行该段代码。
Java语言提供了专门机制以解决这种冲突,有效避免了同一个数据对象被多个线程同时访问。 需要明确的几个问题: synchronized关键字可以作为函数的修饰符,也可作为函数内的语句,也就是平时说的同步方法和同步语句...
并发编程原理学习:synchronized关键字.doc
同样是锁,先说说synchronized和lock的区别: 1.synchronized是java关键字,是用c++实现的;而lock是用java类,用java可以实现 2.synchronized可以锁住代码块,对象和类,但是线程从开始获取锁之后开发者不能进行...
java锁机制Synchronized.pdf
【多线程与高并发原理篇:4_深入理解synchronized】.doc
java锁机制Synchronized java锁机制Synchronized java锁机制Synchronized java锁机制Synchronized
开启了10个线程,每个线程都累加了10000000次,如果结果正确的话总数应该是10*10000000=1000000000.可是运行多次结果都不是这个数,而且每次运行结果都不一样。 线程安全问题主要来源于JMM的设计,主要集中在主内存...