💎一站式轻松地调用各大LLM模型接口,支持GPT4、智谱、星火、月之暗面及文生图 广告
## 方法引用 Java 8 方法引用没有历史包袱。方法引用组成:类名或对象名,后面跟`::`\[^4\],然后跟方法名称。 ~~~java // functional/MethodReferences.java import java.util.*; interface Callable { // [1] void call(String s); } class Describe { void show(String msg) { // [2] System.out.println(msg); } } public class MethodReferences { static void hello(String name) { // [3] System.out.println("Hello, " + name); } static class Description { String about; Description(String desc) { about = desc; } void help(String msg) { // [4] System.out.println(about + " " + msg); } } static class Helper { static void assist(String msg) { // [5] System.out.println(msg); } } public static void main(String[] args) { Describe d = new Describe(); Callable c = d::show; // [6] c.call("call()"); // [7] c = MethodReferences::hello; // [8] c.call("Bob"); c = new Description("valuable")::help; // [9] c.call("information"); c = Helper::assist; // [10] c.call("Help!"); } } ~~~ 输出结果: ~~~ call() Hello, Bob valuable information Help! ~~~ **\[1\]**我们从单一方法接口开始(同样,你很快就会了解到这一点的重要性)。 **\[2\]**`show()`的签名(参数类型和返回类型)符合**Callable**的`call()`的签名。 **\[3\]**`hello()`也符合`call()`的签名。 **\[4\]**`help()`也符合,它是静态内部类中的非静态方法。 **\[5\]**`assist()`是静态内部类中的静态方法。 **\[6\]**我们将**Describe**对象的方法引用赋值给**Callable**,它没有`show()`方法,而是`call()`方法。 但是,Java 似乎接受用这个看似奇怪的赋值,因为方法引用符合**Callable**的`call()`方法的签名。 **\[7\]**我们现在可以通过调用`call()`来调用`show()`,因为 Java 将`call()`映射到`show()`。 **\[8\]**这是一个**静态**方法引用。 **\[9\]**这是**\[6\]**的另一个版本:对已实例化对象的方法的引用,有时称为*绑定方法引用*。 **\[10\]**最后,获取静态内部类中静态方法的引用与**\[8\]**中通过外部类引用相似。 上例只是简短的介绍,我们很快就能看到方法引用的所有不同形式。