彼此依赖的线程如何用Java进行通信?
例如,我正在构建一个带有线程的Web爬虫,这些线程需要来自其他线程的数据。
答案 0 :(得分:28)
以下是Inter线程通信的示例:
public class Main {
public static void main(String[] args) {
Chat m = new Chat();
new T1(m);
new T2(m);
}
}
class Chat {
boolean flag = false;
public synchronized void FromSam(String msg) {
if (flag) {
try {
wait();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
System.out.println(msg);
flag = true;
notify();
}
public synchronized void FromJam(String msg) {
if (!flag) {
try {
wait();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
System.out.println(msg);
flag = false;
notify();
}
}
class T1 implements Runnable {
Chat m;
String[] s1 = { "Hello Jam", "How are you ?", "I am also doing fine!" };
public T1(Chat m1) {
this.m = m1;
new Thread(this, "Sam").start();
}
public void run() {
for (int i = 0; i < s1.length; i++) {
m.FromSam(s1[i]);
}
}
}
class T2 implements Runnable {
Chat m;
String[] s2 = { "HI Sam", "I am good,And U ?", "ha haa" };
public T2(Chat m2) {
this.m = m2;
new Thread(this, "Jam").start();
}
public void run() {
for (int i = 0; i < s2.length; i++) {
m.FromJam(s2[i]);
}
}
}
答案 1 :(得分:23)
这取决于沟通的性质。
等等。
最简单,最可取的线程间通信形式只是等待其他线程的完成。使用Future
:
ExecutorService exec = Executors.newFixedThreadPool(50);
final Future f = exec.submit(task1);
exec.submit(new Runnable() {
@Override
public void run() {
f.get();
// do stuff
}
});
第二个任务在第一个任务完成之前不会执行。
Java 5+有许多并发实用程序来处理这类事情。这可能意味着使用LinkedBlockingQueue
s,CountDownLatch
或许多其他人。
要深入检查并发性Java Concurrency in Practice,必须阅读。
答案 2 :(得分:2)
查看java.util.Observer / java.util.Observable。 它们正是您所寻找的。
答案 3 :(得分:0)
您可以使用2个ExecutorServices,向服务A提交一个Callable实现,该服务A知道后续服务B.当Callable完成它的工作时,它会向服务B提交一个新任务,该任务会对结果执行额外的操作。
如果您需要在两个服务中处理完所有项目后再执行其他工作,则可以使用CountDownLatch或其他障碍。
ExecutorService api非常简单,大多数情况下你可能会使用像.newFixedThreadPool(int threads)这样的东西,并向它提交Runnables / Callables。