rspec/rules/S2212/java/rule.adoc

32 lines
745 B
Plaintext
Raw Normal View History

== Why is this an issue?
Method references are specialized lambda expressions for methods that already have a name. They take the form of ``++objectReference::methodName++`` or ``++ClassName::methodName++``. When a lambda does nothing but call an existing method, it can be much clearer to use a method reference instead.
=== Noncompliant code example
2022-02-04 17:28:24 +01:00
[source,java]
----
Set roster = transferElements(rosterSource,
() -> { return new HashSet<>(); } // Noncompliant
);
----
=== Compliant solution
2022-02-04 17:28:24 +01:00
[source,java]
----
Set roster = transferElements(rosterSource, HashSet::new);
----
ifdef::env-github,rspecator-view[]
'''
== Comments And Links
(visible only on this page)
=== duplicates: S1612
endif::env-github,rspecator-view[]