Ara*_*ram 5 reactive-programming system.reactive rx-java
想法是并行进行3次网络呼叫.(我使用Google作为演示目的的服务.以下工作,但不确定这是否正确或可以简化.如果我必须结合所有三个搜索的响应,我该怎么办?请指教.
public class GoogleSearchRx
{
public static void main(String args[])
{
CountDownLatch latch = new CountDownLatch(3);
search("RxJava").subscribeOn(Schedulers.io()).subscribe(
links -> {
links.forEach(link -> out.println(currentThreadName() + "\t" + link.text()));
latch.countDown();
},
e -> {
out.println(currentThreadName() + "\t" + "Failed: " + e.getMessage());
latch.countDown();
}
);
search("Reactive Extensions").subscribeOn(Schedulers.io()).subscribe(
links -> {
links.forEach(link -> out.println(currentThreadName() + "\t" + link.text()));
latch.countDown();
},
e -> {
out.println(currentThreadName() + "\t" + "Failed: " + e.getMessage());
latch.countDown();
}
);
//run the last one on current thread
search("Erik Meijer").subscribe(
links -> {
links.forEach(link -> out.println(currentThreadName() + "\t" + link.text()));
latch.countDown();
},
e -> {
out.println(currentThreadName() + "\t" + "Failed: " + e.getMessage());
latch.countDown();
}
);
try
{
latch.await();
}
catch (InterruptedException e)
{
e.printStackTrace();
}
}
public static Observable<Elements> search(String q)
{
String google = "http://www.google.com/search?q=";
String charset = "UTF-8";
String userAgent = "ExampleBot 1.0 (+http://example.com/bot)"; // Change this to your company's name and bot homepage!
return Observable.create(new Observable.OnSubscribe<Elements>()
{
@Override public void call(Subscriber<? super Elements> subscriber)
{
out.println(currentThreadName() + "\tOnSubscribe.call");
try
{
Elements links = Jsoup.connect(google + URLEncoder.encode(q, charset)).timeout(1000).userAgent(userAgent).get().select("li.g>h3>a");
subscriber.onNext(links);
}
catch (IOException e)
{
subscriber.onError(e);
}
subscriber.onCompleted();
}
});
}
}
Run Code Online (Sandbox Code Playgroud)
通过"结合所有三个搜索的响应"部分问题,您可能正在寻找Zip.
Observable<Elements> search1 = search("RxJava");
Observable<Elements> search2 = search("Reactive Extensions");
Observable<Elements> search3 = search("Eric Meijer");
Observable.zip(searc1, search2, search3,
new Func3<Elements, Elements, Elements, Elements>() {
@Override
public Elements call(Elements result1, Elements result2, Elements result3) {
// Add all the results together...
return results;
}
}
).subscribeOn(Schedulers.io()).subscribe(
links -> {
links.forEach(link -> out.println(currentThreadName() + "\t" + link.text()));
latch.countDown();
},
e -> {
out.println(currentThreadName() + "\t" + "Failed: " + e.getMessage());
latch.countDown();
}
);
Run Code Online (Sandbox Code Playgroud)
这假设您希望同时处理所有结果(在订阅者中,这里),而不关心用于给定结果的查询.
注意有不同版本的zip功能,从1..1观测服用,并Func1到Func9或FuncN,让您把拉链观测特定或任意大量.
| 归档时间: |
|
| 查看次数: |
4006 次 |
| 最近记录: |