Java FileOutputStream Запись строк - PullRequest
4 голосов
/ 22 июня 2010

У меня проблемы с файлом 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");
        }
    }
}

Ответы [ 3 ]

7 голосов
/ 22 июня 2010

Вы забыли передать параметр конструктора, чтобы указать, что вам нужно добавить данные в файл.

pOUTPUT = new FileOutputStream(DefaultLogFileLocation, true);

Кроме того, почему вы не используете Java Logging Framework?Например, java.util.logging или log4j

Пример конфигурации 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>

2 голосов
/ 22 июня 2010

Я предлагаю использовать FileOutputStream конструктор , который имеет параметр append.

Как правило, знакомьтесь с Javadoc, они могут ответить на простые вопросы, такие как этот, гораздо быстрее, чемлюди здесь.

1 голос
/ 22 июня 2010

Попробуйте использовать pOUTPUT = new FileOutputStream(DefaultLogFileLocation, true);. [Javadoc] [1] здесь.

[1]: http://java.sun.com/j2se/1.4.2/docs/api/java/io/FileOutputStream.html#FileOutputStream(java.io.File, логическое значение)

...