자바 자유 블록
자바 의 자유 블록 은 정적 인 자유 블록 과 비 정적 인 자유 블록 으로 나 뉘 는데 이 두 가지 실행 은 차이 가 있 습 니 다.
비정 상 자유 블록 의 실행 시간 은 구조 함 수 를 실행 하기 전에 입 니 다.
정적 자유 블록 의 실행 시간 은 class 파일 을 불 러 올 때 실 행 됩 니 다.
실행 시간 이 다 르 면 결 과 는:
비 정적 자유 블록 은 여러 번 실 행 될 수 있 습 니 다. 대상 을 초기 화하 면 실 행 됩 니 다. 그러나 정적 자유 블록 은 클래스 가 불 러 올 때 만 실 행 됩 니 다. 일반적으로 클래스 의 정적 변 수 를 초기 화 하 는 데 사 용 됩 니 다.
대상 을 초기 화 할 때마다 비정 상 블록 이 실 행 됩 니 다.만약 에 계승 관계 와 관련 이 있다 면 먼저 아버지 류 의 비정 상 블록 을 집행 한 다음 에 아버지 류 의 구조 함수 이 고 그 다음 에 자신의 자유 블록 이 며 마지막 으로 자신의 구조 함수 이다.정적 블록 의 실행 시 기 는 class 파일 을 불 러 올 때 입 니 다. class 파일 은 한 번 만 불 러 오기 때문에 정적 블록 은 한 번 만 실 행 됩 니 다. 그 다음 에 이 클래스 를 사용 할 때 정적 블록 에 있 는 코드 를 실행 하지 않 습 니 다.
클 라 스 가 불 러 오 는 과정 을 더욱 세밀 하 게 분석 합 니 다. 사실 정적 블록 의 실행 시 기 는 클 라 스 가 불 러 온 후의 초기 화 단계 입 니 다.클래스 Loader 의 loadclass 를 사용 하여 클래스 만 불 러 오고 초기 화 되 지 않 으 면 정적 블록 을 실행 하지 않 습 니 다.Class 를 사용 한 forname (String) 은 기본 initialize 를 true 로 사용 한 경우, 즉 초기 화 되 었 습 니 다.forname (String name, boolean initialize, ClassLoader loader) 을 사용 하면 initialize 를 false 로 설정 하고 정적 블록 을 실행 하지 않 습 니 다.
클 라 스 마 운 트 를 실행 한 후 초기 화 단 계 는 < clinit > 방법 을 실행 합 니 다. 이 방법 은 클래스 변수의 초기 화 문장 과 정적 자유 블록 문장 입 니 다.이 방법 은 자바 의 컴 파일 러 가 정 보 를 수집 한 후에 생 성 된 것 으로 표시 할 수 없 는 호출 입 니 다.
다음은 예 를 들 어 설명 한다.
father.java
package freeblock;
public class father {
static{//
System.out.println("father'sSTATIC free block running");
}
{//
System.out.println("father'sfree block running");
}
public father(){
System.out.println("father'sconstructor running");
}
}
son.java
package freeblock;
public class son extends father{
static{//
System.out.println("son'sSTATIC free block running");
}
{//
System.out.println("son's freeblock running");
}
public son() {
// TODO Auto-generated constructor stub
System.out.println("son'sconstructor running");
}
}
client.java
package freeblock;
public class client {
public static void main(String[] args) {
Class f;
try {
System.out.println("--------beforeload father--------");
f=Class.forName("freeblock.father");
// f=Class.forName("freeblock.father",false,ClassLoader.getSystemClassLoader());
System.out.println("--------afterload father---------");
System.out.println("--------beforeinitial father object--------");
f.newInstance();
System.out.println("--------afterinitial father object--------");
} catch (ClassNotFoundException e) {
e.printStackTrace();
} catch (InstantiationException e) {
e.printStackTrace();
} catch (IllegalAccessException e) {
e.printStackTrace();
}
Class s;
try {
System.out.println("-------beforeload son--------");
s=Class.forName("freeblock.son");
System.out.println("--------afterload son-------");
System.out.println("--------beforeinitial son object----------");
s.newInstance();
System.out.println("--------afterinitial son object-----------");
} catch (ClassNotFoundException e) {
e.printStackTrace();
} catch (InstantiationException e) {
e.printStackTrace();
} catch (IllegalAccessException e) {
e.printStackTrace();
}
}
}
실행 결과:
--------before loadfather--------
father's STATIC free blockrunning
--------after loadfather---------
--------before initial fatherobject--------
father's free block running
father's constructor running
--------after initial fatherobject--------
-------before load son--------
son's STATIC free block running
--------after load son-------
--------before initial sonobject----------
father's free block running
father's constructor running
son's free block running
son's constructor running
--------after initial son object-----------
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
다양한 언어의 JSONJSON은 Javascript 표기법을 사용하여 데이터 구조를 레이아웃하는 데이터 형식입니다. 그러나 Javascript가 코드에서 이러한 구조를 나타낼 수 있는 유일한 언어는 아닙니다. 저는 일반적으로 '객체'{}...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.