4

我一直遇到 Java 文件的问题。它的设计目的是在测试文件中逐行写入日志。不幸的是,每次我调用它时它都会覆盖同一行。

如果有人可以提供帮助,我将永远感激不尽,因为这一直把我逼上绝路!

代码如下。

public abstract class Log {

    protected static String DefaultLogFileLocation = "c:\\LOG.txt";

    public static void ToFile(String pInputString) {
        FileOutputStream pOUTPUT;
        PrintStream pPRINT;
        try
        {
            pOUTPUT = new FileOutputStream(DefaultLogFileLocation);
            pPRINT = new PrintStream(pOUTPUT);
            pPRINT.println (pInputString + "\n");
            pPRINT.close();
        }
        catch (Exception e)
        {
            System.err.println ("Error writing to file");
        }
    }
}
4

3 回答 3

7

您忘记传递构造函数参数来指定您需要将数据附加到文件。

pOUTPUT = new FileOutputStream(DefaultLogFileLocation, true);

另外,为什么不使用一些 Java 日志框架?例如java.util.logginglog4j

写入文件的 log4j 配置示例:

<log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/">
  <appender name="console" class="org.apache.log4j.ConsoleAppender"> 
    <param name="Target" value="System.out"/> 
    <layout class="org.apache.log4j.PatternLayout"> 
      <param name="ConversionPattern" value="%-5p %c{1} - %m%n"/> 
    </layout> 
  </appender> 

  <appender name="FILE" class="org.apache.log4j.DailyRollingFileAppender">
    <param name="file" value="C:\\LOG.TXT" />
    <param name="datePattern" value="'.'yyyy-MM" />
    <param name="append" value="true" />
    <layout class="org.apache.log4j.PatternLayout">
      <param name="ConversionPattern" value="%d [%t] %-5p %C{6} (%F:%L) - %m%n"/> 
    </layout>
  </appender> 
  <root> 
    <priority value ="debug" /> 
    <appender-ref ref="FILE" /> 
    <appender-ref ref="console" /> 
  </root>

于 2010-06-22T16:28:20.230 回答
2

我建议使用有参数的FileOutputStream构造append函数。

一般来说,熟悉 Javadocs,他们可以比这里的人更快地回答这样的简单问题。

于 2010-06-22T16:24:59.467 回答
1

尝试使用pOUTPUT = new FileOutputStream(DefaultLogFileLocation, true);. 请参阅FileOutputStream()

于 2010-06-22T16:24:38.460 回答