Вывод Трассировки перенаправления к Консоли

NullPointerException s - исключения, возникающие при попытке использовать ссылку, которая указывает на отсутствие местоположения в памяти (null), как если бы она ссылалась на объект. Вызов метода по нулевой ссылке или попытка получить доступ к полю нулевой ссылки вызовет функцию NullPointerException. Они наиболее распространены, но другие способы перечислены на странице NullPointerException javadoc.

Вероятно, самый быстрый пример кода, который я мог бы придумать для иллюстрации NullPointerException, be:

public class Example {

    public static void main(String[] args) {
        Object obj = null;
        obj.hashCode();
    }

}

В первой строке внутри main я явно устанавливаю ссылку Object obj равной null. Это означает, что у меня есть ссылка, но она не указывает на какой-либо объект. После этого я пытаюсь обработать ссылку так, как если бы она указывала на объект, вызывая метод на нем. Это приводит к NullPointerException, потому что нет кода для выполнения в местоположении, на которое указывает ссылка.

(Это техничность, но я думаю, что она упоминает: ссылка, которая указывает на null, равна 't то же, что и указатель C, указывающий на недопустимую ячейку памяти. Нулевой указатель буквально не указывает на в любом месте , который отличается от указаний на местоположение, которое оказывается недопустимым.)

74
задан Joel Coehoorn 2 September 2015 в 17:55
поделиться

3 ответа

Можно добавить следующее к .config файлу exe.

<?xml version="1.0"?>
<configuration>
    <system.diagnostics>
        <trace autoflush="true">
            <listeners>
                <add name="logListener" type="System.Diagnostics.TextWriterTraceListener" initializeData="cat.log" />
                <add name="consoleListener" type="System.Diagnostics.ConsoleTraceListener"/>
            </listeners>
        </trace>
    </system.diagnostics>
</configuration>

я включал TextWriter также, в случае, если Вы интересуетесь входом в файл.

156
ответ дан harpo 24 November 2019 в 11:49
поделиться

Отличное решение, но у меня есть ситуация, когда один и тот же вызывающий exe запускает разные библиотеки DLL, поэтому я не хочу изменять файл .config вызывающего exe. Я хочу, чтобы каждая dll обрабатывала собственное изменение вывода трассировки.

Достаточно просто:

Stream outResultsFile = File.Create ("output.txt");
var textListener = new TextWriterTraceListener (outResultsFile);
Trace.Listeners.Add (textListener);

Это, конечно, выводит выходные данные трассировки в файл "output.txt".

11
ответ дан 24 November 2019 в 11:49
поделиться

Джоэл,

Вы можете сделать это вместо метода конфигурации приложения:

Trace.Listeners.Add(new ConsoleTraceListener());

или этого, если вы хотите управлять добавлением или удалением слушателя в течение жизненного цикла приложения:

ConsoleTraceListener listener = new ConsoleTraceListener();
Trace.Listeners.Add(listener);

Trace.WriteLine("Howdy");

Trace.Listeners.Remove(listener);

Trace.Close();
53
ответ дан 24 November 2019 в 11:49
поделиться
Другие вопросы по тегам:

Похожие вопросы: