hadop 소스 코드 연구 의 길 (5) - 자바 동적 에이전트

디자인 모델 을 잘 아 는 사람들 은 대리 모델 에 대해 낯 설 지 않 을 수 있다.대리 대상 과 피 대리 대상 은 일반적으로 같은 인 터 페 이 스 를 실현 하고 호출 자 는 대리 대상 과 상호작용 을 한다.에이전트 의 존 재 는 호출 자 에 게 투명 하고 호출 자 는 인터페이스 만 볼 수 있 습 니 다.프 록 시 대상 은 접근 제어, 원 격 통신, 로그, 캐 시 등 내부 처리 논 리 를 패키지 할 수 있 습 니 다.예 를 들 어 대상 액세스 에이 전 트 는 일반적인 액세스 메커니즘 에 캐 시 지원 을 추가 할 수 있다.이 모델 은 RMI 와 EJB 에서 광범 위 하 게 사용 되 고 있다.전통 적 인 프 록 시 모델 의 실현 은 소스 코드 에 추가 적 인 종 류 를 추가 해 야 합 니 다.이런 종 류 는 일반적으로 손 으로 쓰 거나 도 구 를 통 해 자동 으로 생 성 된다.JDK 5 가 도입 한 동적 에이전트 체 제 는 개발 자가 운영 시간 에 동적 으로 에이전트 클래스 와 대상 을 만 들 수 있 도록 합 니 다.실행 시간 에 여러 인 터 페 이 스 를 실현 하 는 프 록 시 클래스 를 동적 으로 만 들 수 있 습 니 다.모든 프 록 시 클래스 의 대상 은 내부 처리 논 리 를 나타 내 는 Invocation Handler 인터페이스의 실현 과 연 결 됩 니 다.사용자 가 대리 대상 이 대리 하 는 인터페이스 에 있 는 방법 을 호출 했 을 때 이 호출 된 정 보 는 Invocation Handler 의 invoke 방법 에 전 달 됩 니 다.invoke 방법의 매개 변수 에서 프 록 시 대상, 방법 에 대응 하 는 Method 대상 과 호출 된 실제 매개 변 수 를 얻 을 수 있 습 니 다.invoke 방법의 반환 값 은 사용자 에 게 되 돌아 갑 니 다.이런 방법 은 사실상 방법 호출 을 차단 한 셈 이다.AOP 에 익숙 한 사람들 은 이런 사용 패턴 이 낯 설 지 않 을 것 이다.그러나 이런 방식 은 AspectJ 등 AOP 프레임 에 의존 할 필요 가 없다.다음 코드 는 리 소스 인 터 페 이 스 를 실현 한 대상 을 대리 하 는 데 사 용 됩 니 다.이 루어 진 기능 도 매우 간단 하 다. 그것 은 리 소스 인터페이스 에 있 는 operation A 방법 을 사용 하 는 것 을 금지 하 는 것 이다.Test 클래스 에 리 소스 인 터 페 이 스 를 실현 하 는 대상 이 들 어 오 면 실제 프 록 시 대상 으로 돌아 가 이 대상 에서 operation A 방법 을 호출 하려 고 시도 하면 이상 이 발생 합 니 다.
package com.zzu.king;

public interface Resource {
	public void operationA();
	public void operationB();
}
package com.zzu.king;

public class ConcreteResource implements Resource {

	@Override
	public void operationA() {
		System.out.println("Operation A.");
	}

	@Override
	public void operationB() {
		System.out.println("Operation B.");
	}

}
package com.zzu.king;

import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;

public class DynamicProxy implements InvocationHandler {
	private Resource resource;
	
	
	public DynamicProxy() {
		resource = new ConcreteResource();
	}

	public Resource create(){
		Resource returnResource = null;
		
		returnResource = (Resource) Proxy.newProxyInstance(Resource.class.getClassLoader(),new Class[]{ Resource.class },this);
		
		return returnResource;
	}

	public Object invoke(Object proxy, Method method, Object[] args)throws Throwable {
		Object o = null;
		if(method.getName().equals("operationA"))
		//if(method.getName().equals("operation A"))
		{
			throw new UnsupportedOperationException();
		}else{
			o = method.invoke(resource, args);
		}
		return null;
	}
}
package com.zzu.king;

public class Test {

	/**
	 * @param args
	 */
	public static void main(String[] args) {
		DynamicProxy proxy = new DynamicProxy();
		Resource resource = proxy.create();
		resource.operationA();
	}

}

 상기 코드 읽 기: 위 는 간단 한 동적 에이전트 의 예 입 니 다.Dynamic Proxy 는 리 소스 라 는 인 터 페 이 스 를 실현 하지 않 았 지만 리 소스 인터페이스 구현 클래스 의 인 스 턴 스 를 포함 하고 있 음 을 알 수 있 습 니 다.Dynamic Proxy 의 create 방법 에서 Proxy. newProxy Instance 를 호출 하여 Proxy 를 만 들 고 이 Proxy 를 리 소스 인터페이스 와 연결 시 키 고 마지막 으로 Proxy 디 스 플레이 형식 을 리 소스 인터페이스 형식 으로 변환 하여 되 돌려 줍 니 다. 그러면 호출 자 는 Proxy 호출 interface 를 통 해 정의 하 는 방법 을 사용 할 수 있 습 니 다.프 록 시 와 리 소스 인터페이스 가 연결 되 어 있 기 때문에 리 소스 인터페이스 에 대한 방법 호출 은 프 록 시의 invoke 방법 으로 처 리 됩 니 다.한편, invoke 방법 은 서로 다른 방법 에 따라 새로운 실현 을 하거나 프 록 시 에 포 함 된 리 소스 인터페이스 구현 클래스 의 인 스 턴 스 를 직접 호출 하여 처리 합 니 다.위 에서 말 한 것 을 종합해 보면 Dynamic Proxy 로 서 다음 과 같은 세 가지 조건 을 만족 시 켜 야 합 니 다.        1. InvocationHandler 인 터 페 이 스 를 실현 하고 인터페이스 에서 정 의 된 invoke 방법 을 실현 합 니 다.        2. 인터페이스 실현 류 의 인 스 턴 스 를 포함 합 니 다.        3. Proxy. new Proxy Instance 방법 을 통 해 Proxy 와 인터페이스 간 의 연결 을 실현 합 니 다.
정 의 를 되 돌아 보 겠 습 니 다.
 Dynamic Proxy 는 이러한 class 입 니 다. 실행 할 때 생 성 된 class 입 니 다. 생 성 할 때 interface 를 제공 해 야 합 니 다. 그리고 이 class 는 이러한 interface 를 실현 했다 고 주장 합 니 다.너 는 당연히 이 class 의 인 스 턴 스 를 이 interface 의 어떤 것 으로 도 사용 할 수 있다.물론, 이 Dynamic Proxy 는 사실 Proxy 입 니 다. 실질 적 인 작업 을 대신 하지 않 습 니 다. 인 스 턴 스 를 생 성 할 때 handler 를 제공 하여 실제 작업 을 인수 해 야 합 니 다.  。    동적 프 록 시 정의: 하나의 동적 프 록 시 클래스 가 실행 기 implements 인터페이스 에서 인터페이스 구현 클래스 의 방법 을 다른 클래스 (다른 인터페이스 구현 클래스 또는 임의의 클래스) 로 호출 하 는 방법 입 니 다.좀 더 통속 적 으로 말 하고 동태 대 리 를 이해 하려 면 우 리 는 어떤 물건 의 동 태 를 알 아야 한다. 무엇 을 대 리 했 습 니까?우선, 하나의 Proxy 가 인터페이스 방법 을 대리 했다.클 라 스 가 아 닌 인터페이스 입 니 다. abstract 클 라 스 도 아 닙 니 다.그 다음으로 프 록 시가 가지 고 있 는 형 태 는 바 인 딩 된 interface 에 의 해 결정 되 고 동 태 는 여기에 나타난다.

좋은 웹페이지 즐겨찾기