Java中将方法作为参数传递5种方式

Java中将方法作为参数传递5种方式

Java中将方法作为参数传递5种方式

24-06-16

banq

在 Java 中,我们可以使用函数式编程概念将一个方法作为参数传递给另一个方法,具体来说是使用 lambda 表达式、方法引用和函数接口。在本教程中,我们将探讨将方法作为参数传递的几种方法。

1、使用接口和匿名内部类在 Java 8 之前,我们依赖接口和匿名内部类将方法作为参数传递。下面是一个示例来说明这种方法:

interface Operation { int execute(int a, int b);}我们定义一个名为Operation 的接口,该接口只有一个抽象方法execute()。此方法接受两个整数作为参数并返回一个整数。任何实现此接口的类都必须提供execute()方法的实现。

接下来,我们创建一个名为performOperation()的方法来接收两个整数参数和一个Operation实例:

int performOperation(int a, int b, Operation operation) { return operation.execute(a, b);}在这个方法中,我们调用operation.execute(a, b)。这行代码调用作为参数传递的Operation实例的execute()方法。

然后我们调用performOperation()方法并传递三个参数:

int actualResult = performOperation(5, 3, new Operation() { @Override public int execute(int a, int b) { return a + b; }});在performOperation()方法中,使用匿名内部类创建Operation接口的新实例。此类没有名称,但它动态地提供了对execute()方法的实现。

在匿名内部类中,重写了execute()方法。在本例中,它只是将两个整数a和b相加,然后返回两个整数的和。

最后,让我们使用断言验证我们的实现,以确保结果符合预期:

assertEquals(8, actualResult);

2.使用 Lambda 表达式在 Java 8 中,lambda 表达式使将方法作为参数传递更加优雅和简洁。以下是我们如何使用 lambda 实现相同的功能:

@FunctionalInterfaceinterface Operation { int execute(int a, int b);}我们定义一个接口Operation,并使用@FunctionalInterface注释来指示该接口只有一个抽象方法。

接下来,我们调用performOperation()方法并传入两个整型参数和一个Operation接口的实例:

int actualResult = performOperation(5, 3, (a, b) -> a + b);对于第三个参数,我们传递的不是匿名内部类,而是 lambda 表达式(a, b) -> a + b,它表示Operation功能接口的一个实例。

我们应该得到相同的结果:

assertEquals(8, actualResult);

与匿名内部类相比,使用 lambda 表达式简化了语法并使代码更具可读性。

3. 使用方法引用Java 中的方法引用提供了一种将方法作为参数传递的简化方法。它们充当调用特定方法的 lambda 表达式的简写。让我们看看如何使用方法引用实现相同的功能。

我们定义一个名为add()的方法,它接受两个整数a和b作为参数并返回它们的和:

int add(int a, int b) { return a + b;}此方法只是将两个整数相加并返回结果。然后,使用语法object::methodName或 ClassName::methodName将该方法作为引用传递:

int actualResult = performOperation(5, 3, FunctionParameter::add);assertEquals(8, actualResult);此处,FunctionParameter::add指的是FunctionParameter类中的add()方法 。它允许我们将add()方法定义的行为作为参数传递给另一个方法,在本例中为performOperation()方法。

此外,在performOperation()方法中,add()方法引用被视为Operation功能接口的一个实例,该接口具有单个抽象方法execute()。

4. 使用函数类除了方法引用和 lambda 表达式之外,Java 8 还引入了java.util.function包,为常用操作提供了函数式接口。其中,BiFunction是一个函数式接口,表示一个有两个输入参数和一个返回值的函数。下面我们来探索如何使用BiFunction实现类似的功能。

首先,我们创建executeFunction()方法,该方法接受BiFunction作为第一个参数。这意味着它接收一个以两个Integer值作为输入并返回一个Integer 的函数:

int executeFunction(BiFunction function, int a, int b) { return function.apply(a, b);}apply ()方法用于将函数应用于其两个参数。接下来,我们可以使用 lambda 表达式创建BiFunction的实例,并将其作为参数传递给executeFunction()方法:

int actualResult = executeBiFunction((a, b) -> a + b, 5, 3);此 lambda 表达式(a, b) -> a + b表示一个对其两个输入求和的函数。整数5和3分别作为第二和第三个参数传递。

最后,我们使用断言来验证我们的实现是否按预期工作:

assertEquals(8, actualResult);

5. 使用可调用类我们还可以使用Callable将方法作为参数传递。Callable接口是java.util.concurrent包的一部分,表示返回结果并可能引发异常的任务。这在并发编程中特别有用。

让我们探索如何使用Callable将方法作为参数传递。首先,我们创建接受Callable作为参数的executeCallable()方法。这意味着它接收一个返回Integer的任务:

int executeCallable(Callable task) throws Exception { return task.call();}call ()方法用于执行任务并返回结果。它可能会引发异常,因此我们需要适当处理它。我们可以使用 lambda 表达式或匿名内部类定义Callable任务。这里,为了简单起见,我们使用 lambda 表达式:

Callable task = () -> 5 + 3;这个 lambda 表达式表示计算5和3之和的任务。然后我们可以调用executeCallable()方法并将Callable 任务作为参数传递:

int actualResult = executeCallable(task);assertEquals(8, actualResult);使用Callable将方法作为参数传递提供了一种替代方法,这在并发编程场景中特别有用。

相关推荐

都5202年了,居然还有人不知道100M宽带网速是多少
“杏林”的由来,你知道吗?
365bet平台规则

“杏林”的由来,你知道吗?

📅 07-13 👁️ 7006
上海上海动物园游玩攻略简介,上海上海动物园门票/地址/图片/开放时间/照片/门票价格【携程攻略】
世界杯32强巡礼H组丨乌拉圭:神锋老矣 尚能饭否?
365bet滚球网站

世界杯32强巡礼H组丨乌拉圭:神锋老矣 尚能饭否?

📅 07-04 👁️ 8259