새 파생 유형을 생성하거나 재컴파일하거나 원래 유형을 수정하지 않고도 확장 메서드를 사용하여 기존 유형에 메서드를 "추가"할 수 있습니다. 확장 메서드는 정적 메서드의 특수한 형태이지만 확장 형식의 인스턴스 메서드처럼 호출할 수 있습니다. C# 및 Visual Basic으로 작성된 클라이언트 코드의 경우 확장 메서드를 호출하는 것과 형식에 실제로 정의된 메서드를 호출하는 것 사이에는 큰 차이가 없습니다.
사실 C#, Visual Basic, Kotlin 등 많은 프로그래밍 언어가 확장 메소드를 지원하지만, JDK9에서는 오랫동안 우리 Java 언어가 이를 지원하지 않았습니다. Java 함수의 경우 JDK16은 동적 라이브러리 호출 솔루션을 제공할 것을 약속하지만 JDK8의 주요 사용자로서 확장 메서드도 사용하려면 다른 방법을 찾아야 합니다.
/// 扩展方法 public static class ExpandMethod { /// 两个数相加 public static int Sum(this int num,int num2) { return num + num2; } } public class Program { static void Main(string[] args) { /// 调用位置 Console.WriteLine(3.Sum(2)); } }
Imports System.Runtime.CompilerServices Module Module3 Sub Main() Dim ex As New ExampleClass ' 调用位置 ex.ExampleMethod("Extension method") End Sub Class ExampleClass ' Define an instance method named ExampleMethod. Public Sub ExampleMethod() Console.WriteLine("Instance method") End Sub End Class <Extension()> Sub ExampleMethod(ByVal ec As ExampleClass, ByVal stringParameter As String) Console.WriteLine(stringParameter) End Sub End Module
// 扩展函数(本类中扩展方法) class Test1 { var name: String = "boyi.chen" } fun Test1.temp() { println("增加扩展函数,打印扩展类的属性name=${this.name}") } fun main(args: Array<String>) { // 调用位置 Test1().temp() }
Java8 자체는 확장 메서드를 지원하지 않지만, 플러그인을 통해 확장 메서드를 직접 구현할 수 있는 것과 같습니다. 플러그인 중 하나입니다.
Lombok @ExtensionMethod 주석을 통해 프로그램 컴파일 중에 직접 호출되는 정적 메서드를 생성하는 데 도움이 됩니다. 물론 아래의 구체적인 예를 살펴보겠습니다.
/** * lombok测试 * * @author reboot */ @ExtensionMethod(StringUtil.class) public class LombokTest { public static void main(String[] args) { System.out.println("".isBlank()); } /** * 字符串工具 * * @author reboot */ public static class StringUtil { /** * 字符串判空 * * @param targetStr 目标str * @return boolean */ public static boolean isBlank(String targetStr) { return targetStr == null || "".equals(targetStr); } } }
컴파일된 내용에서 메소드가 "".isBlank()에서 LombokTest.StringUtil.isBlank("")로 변환되었음을 볼 수 있습니다. 이러한 방식으로 Lombok은 확장 메소드의 구문 설탕을 제공합니다. .정말 달콤해요.
위 내용은 Java 확장 메서드를 만드는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!