2

我想创建有两个线程的应用程序一个线程读取字符数据另一个线程将其打印到控制台我有以下代码到 interThreadCommunication(假设文件具有类似 stackoverflow 的数据)我正在生成如下输出:

From echo int  115 char value s
From echo int  116 char value t
From echo int  97 char value a
From echo int  99 char value c
From echo int  107 char value k
From echo int  111 char value o
From echo int  118 char value v
From echo int  101 char value e
From echo int  114 char value r
From echo int  102 char value f
From echo int  108 char value l
From echo int  111 char value o
From echo int  119 char value w
From echo int  10 char value 

代码 :

import java.io.*;
class store
{
    int  i;
    public int get()
    {
        return i;
    }
    public void set(int i)
    {
        this.i=i;
    }
}
public class Main
{
    public static void main(String a[])
    {
        store s=new store();
        Thread th=new Thread(new read(s));
        Thread pr=new Thread(new echo(s));
        th.start();
        pr.start();             
    }   
}
class echo implements Runnable
{
    store st;
    public echo(store s)
    {
        st=s;
    }
    public void run()
    {       
        while(true)
        {
            int t=st.get();         
            if(t==-1)
                break;              
            if(t!=32)
            {
System.out.println("From echo int  "+t+" char value "+(char)st.get());  
            }
            st.set(0);
            try
            {
                //Thread.sleep(200);
                while(true)
                {
                    this.wait();
                    if(st.get()!=0)
                        break;

                }
            }
            catch(Exception r)
            {
            }
        }
    }   
}
class read implements Runnable
{
    FileReader fr=null;
    int r;
    store st;
    public read(store s)
    {
        st=s;
    }
    public void run()
    {
        try
        {
            fr=new FileReader("data.txt");
            while(true)
            {
                int r=fr.read();
                st.set(r);
                while(st.get()==0)
                {                   
                    this.wait();
                }   
                if(r==-1)
                    break;              
                try
                {
                    Thread.sleep(200);
                }
                catch(Exception re)
                {
                }
            }   
            st.set(-1);         
        }   
        catch(Exception e)
        {
            e.printStackTrace();
        }
        finally
        {
            try
            {   
                fr.close();
            }
            catch(Exception e)
            {
                e.printStackTrace();    
            }
        }               
    }
}

如果我sleep()从两个类中删除方法,read & echo那么我会得到

From echo int  0 char value 
From echo int  0 char value 
From echo int  0 char value 
.
.
.

我正在使用wait()另一个线程可以处理的方法。我正在以正确的方式进行操作,或者还有其他用于interThreadCommunication的方法

4

2 回答 2

5

您应该考虑使用生产者-消费者模式:
线程 A 将从文件中读取条目,并将它们放入队列中。
线程 B 将从队列中读取条目并打印它们。
您可以使用阻塞队列实现来保证队列的线程安全。我也会考虑不要将一个字符放入队列,而可能是一组字符(一个单词或一行),
以减少入队和出队的数量(因为这些方法是线程安全的,它们具有更高的性能损失比非同步方法)。

于 2012-11-18T14:54:40.070 回答
1

-您可以在读取线程join()上使用方法(即。),以便第一个读取线程在写入线程开始将文件写入控制台之前完全读取文件readThread.join()

例如:

readThread.start();
try{
readThread.join()
}catch(Excpection ex){}

writeThread.start();

-你也可以java.util.concurrent.CountDownLatch用来处理这个。

-我认为SingleThreadExecutor从并发包中也可以为你完成工作。

///////////////////////编辑部分///////////////

-如果您希望它们同时工作,请使用wait/notify组合或await/signal组合concurrent包中的组合。

- ArrayBlockingQueue还将帮助您从concurrent图书馆实现这一目标。

于 2012-11-18T14:52:45.030 回答