如何在Java中运行不同的线程?

时间:2010-03-19 12:23:37

标签: java multithreading

我遇到线程问题。我理解它们是如何工作的,但由于它们都使用相同的方法,我如何运行完全不同的东西,但同时运行不同的线程?

对我来说,似乎他们总是使用相同的标准方法,这使得他们做同样的事情。

所以,假设我有一个很大的.txt文件,我想通过每一行来做一些事情。在这种情况下,我想让每个线程都执行.txt文件的十分之一,但是我不明白线程如何相互通信,以及它们如何组织以便每个线程做正确的部分?< / p>

有人可以解释或帮助我吗?非常感谢!

3 个答案:

答案 0 :(得分:7)

您可以扩展java.lang.Thread(或更好 - 实现java.lang.Runnable)并将参数传递给新对象的构造函数。对于文本文件示例:

public FileReader implements Runnable {
    private int startLine;
    private int endLine;
    public FileReader(int startLine, int endLine) {
       // assign the params to the fields
    }

    public void run() {
       // use the params to read the appropriate lines
    }
}

然后你可以:

new Thread(new FileReader(1, 10)).start();
new Thread(new FileReader(11, 20)).start();
new Thread(new FileReader(21, 30)).start();

答案 1 :(得分:5)

现在你可能应该看看java.util.Concurrent而不是修补原始线程(尽管它们当然可以在适当的地方使用)。线程是一个很大的主题,但通过使用Concurrent包中明确定义的习语,它可以变得更加可忍受。

答案 2 :(得分:-2)

据我所知,线程是并行运行的独立部分,并且始终存在控制并行运行的工作线程的主线程(通常是主线程)。由于主线程完成了该任务,因此不需要线程相互通信。

在您的情况下,您可以让主线程向工作线程发送参数,说明行号 - 对于thread1为0到10,对于thread2等为11到20.工作线程将这些数字作为输入并相应地处理文件