У меня есть следующий (доктрированный) класс в системе, над которой я работаю, и Findbugs генерирует SE_BAD_FIELD, и я пытаюсь понять, почему он сказал бы, что прежде чем исправить это так, как я думал. Причина, по которой я запутался, состоит в том, что описание, похоже, указывает на то, что я не использовал никаких других несериализуемых полей экземпляра в классе, но bar.model.Foo также не сериализуем и используется точно так же (насколько я может сказать), но Findbugs не генерирует никаких предупреждений.
import bar.model.Foo;
import java.io.File;
import java.io.Serializable;
import java.util.List;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
public class Demo implements Serializable {
private final Logger logger = LoggerFactory.getLogger(this.getClass());
private final File file;
private final List<Foo> originalFoos;
private Integer count;
private int primitive = 0;
public Demo() {
for (Foo foo : originalFoos) {
this.logger.debug(...);
}
}
...
}
Мой первоначальный румянец в решении заключается в том, чтобы получить ссылку на журнал с помощью factory вправо, когда я его использую:
public DispositionFile() {
Logger logger = LoggerFactory.getLogger(this.getClass());
for (Foo foo : originalFoos) {
this.logger.debug(...);
}
}
Это не кажется особенно эффективным.
Мысли?