多线程设计模式之Future模式
2017-12-26 20:15
465 查看
1.Future模式
(设计思想同ajax异步请求,用户无需等待请求结果,可以继续操作其他内容)
主程序
public class main {
public static void main(String[] args) {
FutrueClient fc = new FutrueClient();
data request = fc.request("处理的参数");
System.out.println("请求发送成功");
System.out.println("做其他事情");
String result=request.getResult();
System.out.println(result);//返回的结果
}
}
/**
* 描述:客户端
* 作者: dlj
* 时间: 2017年12月26日 下午9:03:25
*/
public class FutrueClient {
public data request(String string) {
data data = new data();
new Thread(new Runnable() {
@Override
public void run() { //开线程处理请求
System.out.println("正在请求数据库处理数据,此过程相对长。。。");
try {
Thread.sleep(2000);//请求服务器过程
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
data.setResult("返回结果");//处理完成放回结果
}
}).start();
return data;//立刻返回一个空数据
}
}
/**
* 描述:结果对象,getResult时如果数据还没有放回则等待,setResult时唤醒getresult
* 作者: dlj
* 时间: 2017年12月26日 下午9:04:55
*/
public class data {
private volatile String result=null;
public String getResult() {
synchronized (this) {
if(result==null){
try {
wait();
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}//等待结果返回
}
}
return result;
}
public void setResult(String string) {
synchronized (this) {
this.result=string;
notify();//唤醒getresult线程
}
}
}
(设计思想同ajax异步请求,用户无需等待请求结果,可以继续操作其他内容)
主程序
public class main {
public static void main(String[] args) {
FutrueClient fc = new FutrueClient();
data request = fc.request("处理的参数");
System.out.println("请求发送成功");
System.out.println("做其他事情");
String result=request.getResult();
System.out.println(result);//返回的结果
}
}
/**
* 描述:客户端
* 作者: dlj
* 时间: 2017年12月26日 下午9:03:25
*/
public class FutrueClient {
public data request(String string) {
data data = new data();
new Thread(new Runnable() {
@Override
public void run() { //开线程处理请求
System.out.println("正在请求数据库处理数据,此过程相对长。。。");
try {
Thread.sleep(2000);//请求服务器过程
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
data.setResult("返回结果");//处理完成放回结果
}
}).start();
return data;//立刻返回一个空数据
}
}
/**
* 描述:结果对象,getResult时如果数据还没有放回则等待,setResult时唤醒getresult
* 作者: dlj
* 时间: 2017年12月26日 下午9:04:55
*/
public class data {
private volatile String result=null;
public String getResult() {
synchronized (this) {
if(result==null){
try {
wait();
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}//等待结果返回
}
}
return result;
}
public void setResult(String string) {
synchronized (this) {
this.result=string;
notify();//唤醒getresult线程
}
}
}
相关文章推荐
- 多线程中的设计模式(Future模式)
- Java 多线程的设计模式之 Future
- 多线程设计模式:Future模式
- 多线程设计模式-Future模式
- future相比于其他并发设计模式的优势(“回调驱动(多线程环境下)”、“消息/事件驱动(Actor模型中))
- 多线程设计模式 - Future模式之JAVA原生实现
- Future模式 多线程设计模式
- java 多线程设计模式之future
- Future --- 多线程设计模式
- 多线程的设计模式之Future模式
- 多线程设计模式--Future模式
- 架构之路--多线程的设计模式之Future模式
- 多线程设计模式Future、Master-Worker和生产者-消费者模型
- Java多线程之并发协作生产者消费者设计模式
- 多线程、设计模式_总结
- 设计模式1:单例模式(考虑多线程的情况)
- 理解多线程设计模式
- 多线程设计模式:Guarded Suspensi…
- Java多线程之并发协作生产者消费者设计模式
- 黑马程序员--读写字节数组,随机读写流,集合IO的思维导图,多线程部分,单例设计模式,线程和进程的概念,Java中的线程的创建方式,线程的随机性,线程的状态图,多线程操作共享数据的安全性,死锁