如果我在java中使用线程,如何打印到文本文件?

时间:2017-02-19 00:18:44

标签: java threadpool

当我使用线程时,我不知道如何打印到文本文件,因为每次它只是创建另一个文件,所以我最终只得到一个结果,这是最后一个,我有尝试了很多东西,并且总是一样的。

这只是代码的一部分,除了打印到文件之外我还必须打印图形,并且我遇到了同样的问题,因为它为每个线程创建了一个图形。

public class Adsda implements Runnable{
    private  int id=0;
    public int number;
    public String file="Time.txt";
    private final PrintWriter outputStream;

    public Adsda(int id) throws FileNotFoundException {
        this.id=id+1;
        this.outputStream=new PrintWriter(this.file);
    }

    public void run() {
        int i,fact=1;  
        this.number=id;//It is the number to calculate factorial    
        long A=System.nanoTime();
        for(i=1;i<=this.number;i++){    
            fact=fact*i;    
        }
        long B=System.nanoTime();
        long t=B-A;
        double tt = (double)t / 1000000000.0;
        System.out.println("Factorial of "+number+" is: "+fact+" Time: "+tt);
        this.outputStream.println("Factorial of: "+this.number+" Time: "+tt);
        this.outputStream.flush();
    }

    public static void main(String[] args) throws FileNotFoundException{  
        ExecutorService executor = Executors.newFixedThreadPool(2);//creating a pool of 2 threads  

        for(int i=0;i<5;i++){
            executor.submit(new Adsda(i) );
        }

        executor.shutdown();
    }

2 个答案:

答案 0 :(得分:0)

你应该创建一个PrintWriter并通过在构造函数中传递它来与线程共享,而不是让每个线程创建自己的PrintWriter(和文件)。虽然这会导致文件包含奇怪的结果。如果您希望按特定顺序使用它们,则应该让线程在其自己的缓冲区中输出结果,并在完成所有线程后,将缓冲区按顺序写入文件。

PrintWriter pw = new PrintWriter(filename);

for(int i=0;i<5;i++){
    executor.submit(new Adsda(i, pw) );
}

答案 1 :(得分:0)

回答你的问题,你有多个执行run方法的线程,所有这些线程都会编写名为&#34; Time.txt&#34;的文件。您应该为每个线程编写一个文件。您也在多个线程之间共享输出流,这本身就是一个问题。在run方法中移动打印编写器创建并使用类似&#34; time&#34;的名称。 + Thread.curentThread()。getID()+&#34; .txt&#34;。那应该解决它。