Java에는 두 가지 바인딩 방법이 있습니다. 하나는 초기 바인딩이라고도 하는 정적 바인딩입니다. 다른 하나는 동적 바인딩(후기 바인딩이라고도 함)입니다.
프로그램 바인딩의 개념:
바인딩은 메서드가 위치한 클래스(메서드 본문)와 메서드 호출을 연결하는 것을 말합니다. 자바의 경우 바인딩은 정적 바인딩과 동적 바인딩, 또는 초기 바인딩과 후기 바인딩으로 구분됩니다.
정적 바인딩(초기 바인딩 컴파일러 바인딩):
프로그램 실행 전 메서드 이미 바인딩되어 있으며 이번에는 컴파일러나 다른 링커에 의해 구현됩니다. . 예: C. Java의 경우 프로그램 컴파일 중 바인딩으로 이해할 수 있습니다. 특히 Java에서는 final, static, private 및 생성자 메서드만 초기 바인딩입니다
동적 바인딩(후기 바인딩 런타임 바인딩):
후기 바인딩: 바인딩 기반 런타임 시 특정 객체의 유형에 대해
언어가 런타임에 바인딩을 구현하는 경우 런타임 중에 개체 유형을 결정하고 적절한 메서드를 각각 호출하는 메커니즘도 제공해야 합니다. 즉, 컴파일러는 현재 객체의 유형을 아직 알지 못하지만 메서드 호출 메커니즘은 자체적으로 조사하여 올바른 메서드 본문을 찾을 수 있습니다. 언어마다 후기 바인딩을 다르게 구현합니다. 이렇게 생각해보세요. 그들은 모두 객체에 특별한 유형의 정보를 삽입해야 합니다.
동적 바인딩 프로세스:
가상 머신은 객체의 실제 유형에 대한 메소드 테이블을 추출합니다.
가상 머신은 메소드 서명을 검색합니다.
메서드 호출
바인딩 관련 요약 정보:
세 가지 개념을 이해한 후 Java가 Late Binding에 속한다는 것을 알았습니다. Java에서는 거의 모든 메서드가 런타임에 바인딩됩니다. 동적으로 바인딩된 메서드는 런타임 시 하위 클래스 또는 기본 클래스에 속합니다. 그러나 특별한 메소드도 있습니다. 정적 메소드와 최종 메소드는 상속될 수 없으므로 해당 값은 컴파일 타임에 결정될 수 있습니다. 특별히 주목해야 할 점은 비공개로 선언된 메서드와 멤버 변수는 하위 클래스에서 상속될 수 없다는 것입니다. 모든 비공개 메서드는 암시적으로 final로 지정됩니다(이로부터 우리는 메서드를 final 유형으로 선언하는 것은 메서드를 덮어쓰는 것을 방지한다는 것을 알고 있습니다. Java에서 동적 바인딩을 효과적으로 끄는 것입니다). Java의 후기 바인딩은 JVM에 의해 구현됩니다. 이를 명시적으로 선언할 필요는 없지만 C++에서는 메소드에 후기 바인딩이 있음을 명시적으로 선언해야 합니다. Java의 업캐스팅 또는 다형성은 동적 바인딩을 통해 달성되므로 동적 바인딩을 이해한다는 것은 업캐스팅 및 다형성을 의미합니다.
Java 메소드의 경우 사전 바인딩된 최종, 정적, 전용 및 생성자 메소드를 제외하고 다른 모든 메소드는 동적으로 바인딩됩니다. 동적 바인딩은 일반적으로 상위 클래스 및 하위 클래스의 변환 선언에서 발생합니다.
예: Parent p = new Children();
구체적인 프로세스는 다음과 같습니다.
1 컴파일러는 객체 선언을 확인합니다. 유형 및 메소드 이름. x.f(args) 메소드를 호출하고 x가 클래스 C의 객체로 선언되었다고 가정하면 컴파일러는 클래스 C의 f라는 모든 메소드와 클래스 C
의 슈퍼 클래스에서 상속된 f 메소드를 열거합니다. 다음으로 컴파일러는 메서드 호출에 제공된 매개변수 유형을 확인합니다. f라는 모든 메소드 중 호출에서 제공하는 매개변수 유형과 가장 일치하는 매개변수 유형이 있는 경우 이 프로세스를 "과부하 해결"이라고 합니다.
3. 동적 바인딩을 사용하여 호출되는 경우 가상 머신은 x가 가리키는 개체의 실제 유형과 일치하는 메서드 버전을 호출해야 합니다. 실제 유형이 D(C의 하위 클래스)라고 가정합니다. 클래스 D가 f(String)를 정의하면 메서드가 호출됩니다. 그렇지 않으면 D의 슈퍼 클래스에서 f(String) 메서드가 검색됩니다.
문제에 대해 생각하기:
메서드 사용자에게 작업을 완료하는 방법을 제공하는 방법. 사용자에게 특별한 요구 사항이 있고 자신만의 방법을 맞춤 설정할 수 있는 경우 어떻게 해야 합니까?
관련 지식:
자식 및 상위 클래스, 인터페이스, 상향 변환, 동적 바인딩
특정 코드:
package com.chengxuyuanzhilu; public interface MyInterfaces { void doting(); } package com.chengxuyuanzhilu; public class Drink implements MyInterfaces { @Override public void doting() { System.out.println("我在喝水"); } } package com.chengxuyuanzhilu; public class Eat implements MyInterfaces { @Override public void doting() { System.out.println("我在吃东西"); } } package com.chengxuyuanzhilu; public class Run implements MyInterfaces { @Override public void doting() { System.out.println("我在奔跑"); } } package com.chengxuyuanzhilu; public class TestDynamicBind { public static void main(String[] args) { MyInterfaces my = null; my = new Eat(); bind(my); my = new Drink(); bind(my); my = new Run(); bind(my); } static void bind(MyInterfaces my){ my.doting(); } }
차이 비교
1. 정적 바인딩이 발생합니다. 런타임 시
2. private, static 또는 final로 수정된 변수나 메서드를 사용하고 정적 바인딩을 사용하세요. 가상 메서드(하위 클래스에 의해 재정의될 수 있는 메서드)는 런타임 개체를 기반으로 동적으로 바인딩됩니다.
3. 정적 바인딩은 클래스 정보를 사용하여 완료하고, 동적 바인딩은 객체 정보를 사용하여 완료해야 합니다.
4. 오버로드된 메서드는 정적 바인딩을 사용하여 완성되고 재정의된 메서드는 동적 바인딩을 사용하여 완성됩니다.
Verification
동적 바인딩은 javap를 사용하여 직접 검증할 수 없으며, 정적 바인딩이 수행되지 않음이 증명되면 동적 바인딩이 수행된다는 의미입니다.
아아아아위 내용은 Java 코드 분석에서 정적 바인딩과 동적 바인딩의 개념 및 차이점의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!