클래스를 처음 사용하는 경우 클래스 로더에 의해 로드되어야 하며 로드 프로세스에는 다음 두 가지 사항이 포함됩니다.
(1) 클래스를 로드할 때 상위 클래스인 경우 클래스가 로드되지 않은 경우 해당 상위 클래스를 먼저 로드해야 합니다.
(2) 클래스가 메모리에 로드된 후 정적 데이터 필드와 정적 블록이 나타나는 순서대로 실행됩니다. 코드.
2. 클래스 생성자를 호출할 때 호출 프로세스에는 다음 세 가지 사항이 포함됩니다.
(1) 상위 클래스의 생성자를 호출합니다. >
(2) 인스턴스 데이터 필드를 초기화하고 코드에 나타나는 순서대로 인스턴스 블록을 실행합니다. (3) 생성자 본문을 실행합니다. 이론은 여전히 실천을 통해 입증되어야 합니다. 이를 증명하는 간단한 예는 다음과 같습니다./** * * @author Sel * * 2014.3.29 */public class InitializationDemo { public static void main(String[] args) { new InitializationDemo(); } public InitializationDemo() { new B(); } { System.out.println("2. Initialization 的实例块。"); } static { System.out.println("1. Initialization 的静态块。"); } }class A { A() { System.out.println("6. A 的构造函数体。"); } { System.out.println("5. A 的实例块。"); } static { System.out.println("3. A 的静态块。"); } }class B extends A { B() { System.out.println("8. B 的构造函数体。"); } { System.out.println("7. B 的实例块。"); } static { System.out.println("4. B 的静态块。"); } }위의 예에서는 클래스의 각 부분에 해당 텍스트를 출력하므로 출력에서 실행 순서를 확인할 수 있습니다. 의 해당 출력은 다음과 같습니다.
1. Initialization 的静态块。 2. Initialization 的实例块。 3. A 的静态块。 4. B 的静态块。 5. A 的实例块。 6. A 的构造函数体。 7. B 的实例块。 8. B 的构造函数体。
1. 먼저 초기화 클래스를 사용한 다음 초기화 클래스가 로드되어 해당 정적 블록이 실행되고 1이 출력됩니다. 2. 프로그램이 초기화 생성자를 호출합니다. 의 초기화 클래스가 실행되므로 2가 출력됩니다. 3. 그러면 초기화의 생성자 본문, 즉 new B()를 실행합니다. 4. 클래스 B의 상위 클래스가 A이므로 B를 로드하기 전에 A를 먼저 로드해야 하므로 이때 A의 로드 프로세스, 즉 정적 블록이 실행됩니다. A가 실행되었으므로 3이 출력됩니다. 5. A가 로드된 후 B가 로드되는 시점입니다. 즉, 정적 프로세스가 실행됩니다. B의 블록이 실행되므로 4가 출력됩니다. 6. 로딩이 완료된 후 이때 코드에 따라 B의 생성자인 new B()를 실행하므로 이 시점에서 이때 상위 클래스 A의 생성자가 먼저 호출되어야 하므로 A의 인스턴스 블록과 생성자 본문이 순서대로 실행되어 7이 출력됩니다. 마지막으로 "실제" 실행은 B의 생성자입니다. (이전에는 new B()를 실행한다고 했지만 다른 것을 호출하고 있었기 때문에) B의 인스턴스 블록과 생성자 바디가 순차적으로 실행되어 7과 8이 출력된다. 위는 Java의 정적 블록과 인스턴스 블록에 대한 내용입니다. 더 많은 관련 내용은 PHP 중국어 홈페이지(www.php.cn)를 주목해주세요!