註解可在 Java 中透過介面或抽象類別定義,提供類別、方法或域的元資料。介面作為註解類型:實作java.lang.annotation.Annotation 接口,如:@MyAnnotation("Hello, world!")抽象類別作為註解類型:擴展java.lang.annotation.Annotation 抽象類別,如:@MyAnnotation(value ="Hello, world!")實戰案例:使用註解驗證方法參數,例如:@NotNull,用於檢查參數是否為非空,否則拋出例外。
註解中的介面與抽象類別
#註解在Java 中用於向編譯器提供有關類別、方法和域的元數據。介面和抽象類別可以用作註解類型,讓你可以定義註解的特定約束。
介面作為註解類型
介面可以作為註解類型,透過實作 java.lang.annotation.Annotation
介面。例如:
public @interface MyAnnotation { String value(); }
使用這個註解:
@MyAnnotation("Hello, world!") public class MyClass {}
抽像類別作為註解類型
抽象類別也可以作為註解類型,透過擴展
抽象類別。例如:public abstract @interface MyAnnotation {
String value();
}
使用這個註解:
@MyAnnotation(value="Hello, world!") public class MyClass {}實戰案例
在下列實戰案例中,我們將使用註解來驗證方法參數:<pre class='brush:java;toolbar:false;'>import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.PARAMETER)
public @interface NotNull {
}
public class MyClass {
public void myMethod(@NotNull String param) {
// 验证参数 non-null
if (param == null) {
throw new IllegalArgumentException("参数不能为空!");
}
// 使用参数...
}
}</pre>
使用這個註解:<pre class='brush:java;toolbar:false;'>public class Client {
public static void main(String[] args) {
MyClass myClass = new MyClass();
myClass.myMethod("Hello, world!");
}
}</pre>
執行這段程式碼會拋出
以上是介面和抽象類別在 Java 註解中的應用的詳細內容。更多資訊請關注PHP中文網其他相關文章!