如何使用forSach与slf4j.logger.info

时间:2015-12-28 21:11:25

标签: java lambda java-8 log4j slf4j

我正在开发一个基于Spring Batch,Spring Boot,slf4j和Java 8的简单应用程序。我想尽可能多地使用lambda用于学习目的。 “myPojos.stream()forEach((myPojo) - &gt; {log.info(myPojo);});”是什么问题下面?该消息抱怨“......不适用于参数<? extends MyPojo”。请注意,所有其他三个日志行都正常工作。

public class CustomItemWriter implements ItemWriter<MyPojo> {

    private static final Logger log = LoggerFactory.getLogger(CustomItemWriter.class);

    @Override
    public void write(List<? extends MyPojo> myPojos) throws Exception{
        myPojos.stream().forEach((myPojo)-> {log.info(myPojo);});//error
        myPojos.forEach(System.out::println);//it works
        myPojos.stream().forEach((myPojo) -> {System.out.println(myPojo);}); //it works
        log.info("finish"); //it works
    }

}

2 个答案:

答案 0 :(得分:6)

Logger.info收到String,因此您必须将MyPojo转换为包含toString()的字符串:

myPojos.stream().forEach((myPojo) -> {log.info(myPojo.toString());});

请注意,由于你有一个语句lambda,你可能会失去一些健壮性:

myPojos.stream().forEach(myPojo -> log.info(myPojo.toString()));

答案 1 :(得分:1)

Java 8 lambda样式

myPojos.stream().forEach(log::info);