>Java >java지도 시간 >Java Reflection을 사용하여 런타임에 클래스를 검사하고 조작하는 방법은 무엇입니까?

Java Reflection을 사용하여 런타임에 클래스를 검사하고 조작하는 방법은 무엇입니까?

Karen Carpenter
Karen Carpenter원래의
2025-03-11 17:46:16215검색

런타임에서 클래스를 검사하고 조작하기 위해 Java Reflection을 사용하는 방법

Java Reflection은 컴파일 타임이 아니라 런타임에 클래스 및 멤버 (필드, 방법, 생성자)를 검사하고 상호 작용하는 강력한 메커니즘을 제공합니다. 이것은 java.lang.reflect 패키지를 통해 달성됩니다. 다음은 사용 방법에 대한 고장입니다.

먼저 검사하려는 클래스를 나타내는 클래스 객체를 얻어야합니다.

  • class.forname () : 사용하여 완전한 자격을 갖춘 클래스 이름을 문자열로 간주합니다. 예 : 클래스 & lt;? & gt; myclass = class.forname ( "com.example.myclass"; 이 메소드는 classNotFoundException 를 던질 수 있음을 참고하십시오. 예 : myclass myObject = new MyClass (); 클래스 & lt;? & gt; MyClass = myObject.getClass ();
  • 원시 유형의 클래스 리터럴을 사용하여 int 와 같은 원시 유형의 경우

를 사용할 수 있습니다. 생성자 : 생성자 & lt;? & gt; [] 생성자 = myclass.getConstructors (); 이것은 모든 public 생성자의 배열을 반환합니다. 특정 생성자 (예 : 매개 변수 유형별)를 얻으려면 myclass.getConstructor (parametertype1.class, parametertype2.class, ...);

  • 방법 : 방법 [] method = myclass.getMethods (); 특정 메소드를 얻으려면 <code> myclass.getMethod ( "MethodName", ParameterType1.class, ParameterType2.class, ...); 를 사용하여 비 공개 메소드에 액세스하려면 myclass.getDeclaredMethods ()
  • fields fields를 사용하십시오. myclass.getfields (); 이것은 모든 public 필드의 배열을 반환합니다. 메소드와 유사하게 비공개 필드에 대한 myclass.getDeclaredFields () 를 사용하십시오.
  • method 또는 field 객체를 얻은 후 method.invoke (object) 및 angud> and and anguveke (객체) 를 사용하여 필드를 호출하거나 수정할 수 있습니다. field.get (Object) / field.set (Object, Value) . invocationTargetexception , 불법 행위 nosuchmethodexception .

    와 같은 잠재적 예외를 처리해야합니다. 그러나 추가 단계가 필요합니다. 간단히 myclass.getDeclaredFields () 또는 myclass.getDeclaredMethods () 를 호출하면 개인 회원을 포함한 모든 회원에게 액세스 할 수 있습니다. 그러나 직접 액세스하거나 수정하려고 시도하면 여전히 불법 행위 예고 를 던질 수 있습니다. 이를 극복하려면 field 또는 메소드 객체에서 setAccessible (true) 메소드를 사용해야합니다. privatefield.setAccessible (true); 개체 값 = privatefield.get (myObject); // Private Field PrivateField에 액세스하십시오 (MyObject, NewValue); // 개인 필드 수정

    setAccessible (true) 를 사용하여 조심스럽게 수행해야합니다. 액세스 수정자를 우회하여 잠재적으로 캡슐화를 깨고 코드에서 예상치 못한 결과를 초래합니다.

    내 응용 프로그램에서 Java 반사를 광범위하게 사용하는 성능은 무엇입니까?

    Java 반사를 사용하면 응용 프로그램의 성능에 크게 영향을 줄 수 있습니다. 그 이유는 다음과 같습니다.

    • 동적 조회 : 반사에는 클래스 및 멤버의 런타임 조회가 포함됩니다. JVM은 컴파일 시간의 세부 사항을 알지 못하기 때문에 직접 정적 액세스보다 느리게 진행됩니다.
    • 보안 확인 : JVM은 반사 중에 보안 검사를 수행하여 오버 헤드를 추가합니다. 반사는이 최적화를 방해하여 효율적인 기계 코드를 초래합니다.
    • 메모리 소비 증가 : 반사는 특히 많은 객체를 동적으로 생성하는 데 사용되는 경우 메모리 사용량을 증가시킬 수 있습니다.

    따라서 반사를 신중하게 사용하는 것이 중요합니다. 응용 프로그램의 성능 크리티컬 부분의 경우 직접 메소드 호출 및 정적 액세스가 항상 선호됩니다. 동적 동작이 절대적으로 필수적이고 성능 비용이 허용되는 경우에만 반사를 고려하십시오.

    Java 반사를 사용하여 런타임에서 다른 클래스의 동적 인스턴스화 객체를 어떻게 인스턴스화 할 수 있습니까?

    Java 반사는 구성 객체를 사용하여 동적 객체 인스턴스화를 허용합니다. 방법은 다음과 같습니다.

     <code class="java"> String classname = "com.example.myclass & quot;; // 구성 파일, 사용자 입력 등에서 이것을 얻으십시오. 클래스 & lt;? & gt; myclass = class.forname (classname); 생성자 & lt;? & gt; 생성기 = myclass.getConstructor (String.class, int.class); // 생성자 매개 변수 지정 객체 myObject = constructor.newinstance ( "hello", 123); // 객체를 인스턴스화합니다 </code> 

    이 코드 스 니펫은 className 로 지정된 클래스의 인스턴스를 동적으로 생성합니다. getConstructor 메소드는 매개 변수 유형에 따라 적절한 생성자를 찾습니다. newinstance 메소드는 해당 생성자를 사용하여 클래스의 인스턴스를 만듭니다. classNotFoundException , nosuchmethodexception , InstantiationException 및 invocationTargetexception 와 같은 잠재적 예외를 처리하십시오. 이 접근법을 사용하면 코드의 클래스 이름을 하드 코딩 할 필요없이 런타임 정보를 기반으로 다양한 클래스의 객체를 만들 수 있습니다. 이것은 프레임 워크 및 플러그인 아키텍처에 특히 유용합니다.

    위 내용은 Java Reflection을 사용하여 런타임에 클래스를 검사하고 조작하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

    성명:
    본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.