SONAR:将此 lambda 替换为方法引用

Sonar 告诉我用方法引用替换这个 lambda"

Sonar tells me "Replace this lambda with a method reference"

public class MyClass {

    private List<SomeValue> createSomeValues(List<Anything> anyList) {
        return anyList //
               .stream() //
               .map(anything -> createSomeValue(anything)) //
               .collect(Collectors.toList());
   }

    private SomeValue createSomeValue(Anything anything) {
        StatusId statusId = statusId.fromId(anything.getStatus().getStatusId());
        return new SomeValue(anything.getExternId(), statusId);
    }

}

这可能吗?我尝试了几件事,比如

Is this possible here? I tried several things, like

.map(MyClass::createSomeValue) //

但是我需要将方法更改为静态.而且我不是静态方法的忠实粉丝.

but I need to change the method to static then. And I am not a big fan of static methods.

SonarQube 的解释是:

Explanation of SonarQube is:

方法/构造函数引用比使用 lambda 更紧凑和可读,因此是首选.

Method/constructor references are more compact and readable than using lambdas, and are therefore preferred.

推荐答案

是的,你可以使用 this::createSomeValue:

private List<SomeValue> createSomeValues(List<Anything> anyList) {
    return anyList //
            .stream() //
            .map(this::createSomeValue) //
            .collect(Collectors.toList());
}

这种方法参考称为"对特定对象的实例方法的引用".在这种情况下,您指的是实例 this 的方法 createSomeValue.

This kind of method reference is called "Reference to an instance method of a particular object". In this case, you are referring to the method createSomeValue of the instance this.

使用 lambda 表达式是否更好"是一个见仁见智的问题.但是,您可以参考 this answer/brian-goetz">Brian Goetz 解释了为什么首先在语言中添加方法引用.

Whether it is "better" or not that using a lambda expression is a matter of opinion. However, you can refer to this answer written by Brian Goetz that explains why method-references were added in the language in the first place.

相关文章