1

我需要独立执行 2 项任务。

第一个任务

每分钟一次,它应该检查特定文件夹中是否有任何文件。如果有,它应该将文件的名称添加到队列中。

这可以按如下方式完成:

import java.util.concurrent.ScheduledExecutorService;
import java.util.concurrent.ScheduledThreadPoolExecutor;
import java.util.concurrent.TimeUnit;


public class schedulerExample extends Thread{

    public void checkFile()
    {
        System.out.println("checking whether file exist in folder");

    }

    public void getFiles()
    {
        System.out.println("getting the file names");
    }

    public void enqueueFiles()
    {
        System.out.println("add files to queue");
    }
    public static void main(String[] args) {

    final schedulerExample obj = new schedulerExample();
    ScheduledExecutorService executor = new ScheduledThreadPoolExecutor(1);
    executor.scheduleAtFixedRate(new Runnable() {

        @Override
        public void run() {

            obj.checkFile();
            obj.getFiles();
            obj.enqueueFiles();

        }
    }, 0, 1, TimeUnit.MINUTES);


    }

}

第二个任务

如果队列为空,则休眠一分钟,否则逐个处理队列中的文件。

public class processModel extends Thread{

    public static void getQueueSize(int size)
    {
        System.out.println("getting queue size");

    }
    public void dequeue()
    {

        // dequeue the queue
        System.out.println("dequeue");

    }

    public void processFile()
    {
        // process the file
        System.out.println("process file");
    }

    public static void main(String[] args) {
        final boolean flag = true;
        final int size = 9;
        final processModel obj = new processModel();
        Thread t1 = new Thread(){
            public void run()
            {
                while(flag)
                {
                obj.dequeue();
                obj.processFile();
                getQueueSize(size);
                    if(size == 0)
                    {
                        try
                        {
                        Thread.sleep(60000);
                        }
                        catch(InterruptedException e)
                        {

                        }
                    }
                }

            }

        };

        t1.start();

    }

}

现在我需要在一个班级同时做这两个。那可能吗?

一个线程应该每分钟获取一次文件。另一个线程应该一个接一个地执行文件。如果没有文件,它会等待一分钟并再次检查。在第二种方法中,我使用了无限循环——而不是那样,有没有一种方法可以让我一个接一个地执行事情?

4

2 回答 2

3

您可能需要考虑将Callable与 java ExecutorService一起使用。这可用于轻松分解任务并允许它们同时运行。除此之外,您可以获得一个 Future ,它允许您随时检查结果(如果没有完成,则推迟)。

有一本关于 java 和并发的好书叫做“Concurrency in Practice”。

除此之外,Java 7 还具有允许在目录上进行文件侦听器的新功能。这可能允许您抽象这种“检查和循环”功能。

于 2012-10-19T21:33:37.783 回答
1

当您从队列对象中获取文件以及向其中添加文件时,在队列对象上进行同步。

在读取的线程中,wait()如果队列为空,则调用。
在检查新文件的线程中,在将notify()新文件添加到队列后调用。

这就是通常的做法。


您还应该防止将正在处理的文件添加到队列中。

于 2012-10-19T21:33:14.740 回答