이 글은 주로 자바의 주석 메커니즘과 그 원리에 대한 정보를 소개합니다. 이 글이 모든 사람이 이 부분을 이해하고 익히는 데 도움이 되기를 바랍니다. 도움이 필요한 친구들은 이 글을 참고할 수 있습니다.
자바의 주석 메커니즘과 원리 원리에 대한 자세한 설명
주석이란 무엇입니까
주석은 우리가 흔히 사용하는 @Override 및 @Deprecated와 같이 메타데이터라고도 합니다. 주석은 JDK1.5 버전에 도입된 기능입니다. 패키지, 클래스, 인터페이스, 필드, 메소드 매개변수, 지역 변수 등에 주석을 달 수 있습니다. 주요 기능은 다음과 같습니다.
코드에서 식별된 메타데이터를 통해 문서를 생성하고 javadoc 문서를 생성합니다.
컴파일 확인, 코드에서 식별된 메타데이터를 통해 컴파일러는 컴파일 중에 확인하고 확인할 수 있습니다.
컴파일 시 동적 처리. 동적으로 생성되는 코드와 같이 코드에서 식별된 메타데이터를 통해 컴파일 시 동적 처리.
런타임 동적 처리. 반사 주입 인스턴스 사용과 같이 코드에서 식별된 메타데이터를 통한 런타임 동적 처리입니다.
일반 주석은 세 가지 범주로 나눌 수 있습니다.
첫 번째 범주는 @Override, @Deprecated 및 @SuppressWarnings를 포함한 Java 자체 표준 주석으로, 특정 메서드를 재정의하고 특정 메서드를 나타내는 데 사용됩니다. 클래스나 메소드는 더 이상 사용되지 않으며 무시하라는 경고로 표시됩니다. 컴파일러는 이러한 주석을 표시한 후 이를 확인합니다.
첫 번째 카테고리는 메타 주석입니다. 메타 주석은 @Retention, @Target, @Inherited를 포함하여 주석을 정의하는 데 사용되며 @Retention은 주석이 유지되는 단계를 나타내는 데 사용됩니다. , @Target은 Annotation을 나타내는 데 사용되며, @Inherited는 Annotation을 상속할 수 있음을 나타내는 데 사용되며, @Documented는 javadoc 문서 생성 여부를 나타내는 데 사용됩니다.
첫 번째 카테고리는 사용자 정의 주석입니다. 필요에 따라 주석을 정의할 수 있으며, 메타 주석으로 사용자 정의 주석을 달 수 있습니다.
주석의 사용
주석의 사용은 매우 간단합니다. 주석이 필요한 곳에 주석을 표시하기만 하면 됩니다. 예를 들어, 메소드에 주석을 답니다.
public class Test { @Override public String tostring() { return "override it"; } }
예를 들어, 클래스에 주석을 답니다. :
@Deprecated public class Test { }
그래서 Java에 내장된 주석을 직접 사용할 수 있지만 일부 주석을 직접 정의해야 하는 경우가 많습니다. 예를 들어 Common Spring은 객체 간의 종속성을 관리하기 위해 많은 수의 주석을 사용합니다. @Test를 통해 특정 클래스에 문자열을 삽입하고, @TestMethod를 통해 특정 메서드에 문자열을 삽입하는 등 자체 주석을 정의하는 방법을 살펴보겠습니다.
①테스트 주석을 생성하고 클래스에 적용되도록 선언하고 런타임까지 유지합니다. 기본값은 기본값입니다.
@Target({ElementType.TYPE}) @Retention(RetentionPolicy.RUNTIME) public @interface Test { String value() default "default"; }
②TestMethod 주석을 생성하고 메서드에 대해 작동하도록 선언하고 런타임까지 유지합니다.
@Target({ElementType.METHOD}) @Retention(RetentionPolicy.RUNTIME) public @interface TestMethod { String value(); }
③테스트 클래스는 실행 후 default와 tomcat-method라는 두 개의 문자열을 출력합니다. @Test는 값을 전달하지 않기 때문에 기본값이 출력되고 @TestMethod는 삽입된 문자열을 출력합니다.
@Test() public class AnnotationTest { @TestMethod("tomcat-method") public void test(){ } public static void main(String[] args){ Test t = AnnotationTest.class.getAnnotation(Test.class); System.out.println(t.value()); TestMethod tm = null; try { tm = AnnotationTest.class.getDeclaredMethod("test",null).getAnnotation(TestMethod.class); } catch (Exception e) { e.printStackTrace(); } System.out.println(tm.value()); } }
Annotation의 원리
앞에서는 Java에 내장된 Annotation을 활용하는 방법과 Annotation을 Customizing하는 방법에 대해 소개했다. 더 큰 Java 시스템을 지원합니다. 위의 Custom Annotation 예제로 돌아가서 AnnotationTest 클래스에 AnnotationTest를 적용하면 AnnotationTest.class.getAnnotation(Test.class)를 통해 런타임에 Annotation 선언 값을 얻을 수 있다. 위 문장을 보면 클래스 구조에서 Test 주석을 얻는 것을 볼 수 있으므로 어느 시점에서 주석이 클래스 구조에 추가되었을 것입니다.
@Test("test") public class AnnotationTest { public void test(){ } }
컴파일러는 Java 소스 코드를 구문 분석하고 클래스 파일을 생성합니다. 컴파일러는 주석 기호도 처리합니다. JVM 사양에 따르면 클래스 파일 구조는 엄격하게 정렬된 형식입니다. 클래스 구조에 정보를 추가하는 유일한 방법은 정보를 클래스 구조의 속성에 저장하는 것입니다. 클래스, 필드 및 메소드는 클래스 구조에 고유한 특정 테이블 구조를 갖고 있으며 각각 고유한 속성을 가지고 있습니다. 주석의 경우 작업 범위도 다를 수 있습니다. 또는 메서드를 사용하는 경우 컴파일러는 클래스, 필드 또는 메서드의 속성에 주석 정보를 저장합니다.
AnnotationTest 클래스가 컴파일된 후 해당 AnnotationTest.class 파일에는 RuntimeVisibleAnnotations 속성이 포함됩니다. 이 주석은 클래스에 적용되므로 이 속성은 클래스의 속성 세트에 추가됩니다. 즉, Test 주석의 키-값 쌍 value=test가 기록됩니다. JVM이 AnnotationTest.class 파일 바이트코드를 로드할 때 RuntimeVisibleAnnotations 속성 값을 AnnotationTest의 Class 객체에 저장하므로 Test 주석 객체는 AnnotationTest.class.getAnnotation(Test.class)를 통해 얻은 다음 The Test를 통해 얻을 수 있습니다. 주석 객체는 테스트에서 속성 값을 얻습니다.
여기서 질문이 있을 수 있습니다. 테스트 주석 개체가 무엇입니까? 실제로 컴파일된 주석의 본질은 Annotation 인터페이스를 상속하는 인터페이스이므로 @Test는 실제로 "Test가 Annotation을 확장하는 공용 인터페이스"입니다. 이를 AnnotationTest.class.getAnnotation(Test.class)를 통해 호출하면 JDK는 동적 프록시를 통해 생성 Test 인터페이스를 구현하고 RuntimeVisibleAnnotations 속성 값을 이 객체에 설정하는 객체입니다. 이 객체는 Test 주석 객체이며 주석 값은 해당 value() 메서드를 통해 얻을 수 있습니다.
Java 주석 구현 메커니즘의 전체 프로세스는 위에 표시된 것과 같습니다. 구현에는 컴파일러와 JVM의 협력이 필요합니다.
위 내용은 Java의 주석 메커니즘 및 원리에 대한 자세한 예의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!