在java中,如何在线程中获取文件名

时间:2011-04-11 06:56:57

标签: java logging

我有ArrayList名为fileList。它包含文件名列表。通过for循环,我为每个文件名创建线程并使用TailListener Java API监视文件。现在我想获取文件中存在的每条消息的文件名。

fileListener= new fileListener();

for(int i=0;i<fileList.Size();i++)
{           
   monitorFile(filelist.get(i));            
}

private void monitorFile(String logFile) {

         File pcounter_log = new File(logFile);

         Tailer = new Tailer(pcounter_log, fileListener, 5000);   

         ThreadPoolExec.scheduleAtFixedRate(Tailer, 5, 5, TimeUnit.SECONDS);    
    }


public class fileListener extends TailerListenerAdapter {

String s= "abc";

    public void handle(String line) {

            if(line.contains(s)){
                System.out.println(line);
            }
    }
}

在上面的代码中,我如何获取相应日志消息的文件名?

1 个答案:

答案 0 :(得分:3)

一种简单的方法是为每个文件使用单独的侦听器:

将您的fileListener课程更改为以下内容:

public class FileListener extends TailerListenerAdapter {

    private final String fileName;

    public FileListener(String fileName) {
         this.fileName = fileName;
    }

    public void handle(String line) {
         if(line.contains(s)){
             System.out.println(fileName + ": " + line);
         }
    }
}

然后只为您监控的每个文件实例化一个新的FileListener

private void monitorFile(String logFile) {
     File pcounter_log = new File(logFile);
     Tailer = new Tailer(pcounter_log, new FileListener(logFile), 5000);   
     ThreadPoolExec.scheduleAtFixedRate(Tailer, 5, 5, TimeUnit.SECONDS);    
}