자바 디자인 모드 의 동적 에이전트, 정적 에이전트
4633 단어 학습 노트
1. 프 록 시 모드 프 록 시 모드 는 프 록 시 대상 의 내부 코드 구 조 를 바 꾸 지 않 을 때 프 록 시 대상 의 기능 을 증가 하거나 개선 하 는 것 으로 정적 프 록 시 와 동적 프 록 시 로 나 뉜 다.1. 정적 대리 대상 과 피 대리 대상 이 같은 인 터 페 이 스 를 실현 하려 면 대리 대상 은 피 대리 대상 의 인용 을 가지 고 피 대리 대상 의 방법 을 호출 하기 전에 또는 그 후에 새로 추 가 된 기능 을 삽입 하여 피 대리 대상 의 기능 을 강화 하 는 역할 을 해 야 한다.실현 코드 는 다음 과 같다. a. 통일 적 으로 실현 할 인터페이스 package com. heyuanjun. proxy;public interface IProxy { String save(); String delete(); }
b. IntelliJ IDEA / / (Powered by Fernflower decompiler) 의. class 파일 에서 에이전트 대상 / / / 소스 코드 에 의 해 다시 생 성 됨 / / /
package com.heyuanjun.proxy;
public class Represented implements IProxy { public Represented() { }
public String save() {
System.out.println(" ");
return " ";
}
public String delete() {
System.out.println(" ");
return " ";
}
}
c. IntelliJ IDEA / / (Fernflower decompiler 에 의 해 구동) 에 의 해. class 파일 에서 재생 성 된 에이전트 대상 / / / 소스 코드 / /
package com.heyuanjun.proxy;
public class MyProxy implements IProxy {IProxy target; / 프 록 시 대상 참조 보유
public MyProxy(IProxy target) {
this.target = target;
}
public String save() {
System.out.println(" , "); //
String returnValue = this.target.save();
System.out.println(" , ");
return returnValue;
}
public String delete() {
return null;
}
}
d. 테스트 패키지 com. heyuanjun. proxy;
public class TestProxy { public TestProxy() { }
public static void main(String[] args) {
IProxy iProxy = new MyProxy(new Represented()); //
iProxy.save(); // ,
}
} 정적 에이전트 의 장단 점: 프 록 시 모델 을 가 진 장점 은 업무 코드 와 비 업무 대 리 를 분리 하 는 것 입 니 다. 그러나 단점 도 뚜렷 합 니 다. 하 나 는 프 록 시 류 와 비 프 록 시 류 가 똑 같은 인 터 페 이 스 를 실현 해 야 한 다 는 것 입 니 다. 인터페이스 가 바 뀌 었 을 때 프 록 시 류 도 해당 하 는 변경 이 필요 합 니 다. 만약 에 프로젝트 에서 정적 대 리 를 대량으로 사용 하면의심 할 여지없이 프로젝트 의 유지 보수 에 매우 큰 어려움 을 증가 시 켰 다.둘째, 정적 대 리 는 강화 해 야 할 모든 방법 에 해당 하 는 프 록 시 방법 을 만들어 야 합 니 다. 그러면 많은 코드 량 이 증가 합 니 다.
package com.heyuanjun.proxy;
import java.lang.reflect.InvocationHandler; import java.lang.reflect.Method; import java.lang.reflect.Proxy;
public class ProxyFactory { Object target;
ProxyFactory(Object target) {
this.target = target;
}
public Object getProxyInstance() {
return Proxy.newProxyInstance(this.target.getClass().getClassLoader(), this.target.getClass().getInterfaces(), new InvocationHandler() {
public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
System.out.println(" ");
Object returnValue = method.invoke(ProxyFactory.this.target, args);
System.out.println(" ");
return returnValue;
}
});
}
} b, IntelliJ IDEA / / (Powered by Fernflower decompiler) 의. class 파일 에서 대 리 된 대상 / / / 소스 코드 / /
package com.heyuanjun.proxy;
public class Represented implements IProxy { public Represented() { }
public String save() {
System.out.println(" ");
return " ";
}
public String delete() {
System.out.println(" ");
return " ";
}
} c, IntelliJ IDEA / / (Fernflower decompiler 에 의 해 구동) 에 의 해. class 파일 에서 다시 생 성 된 테스트 / / / 소스 코드 / /
package com.heyuanjun.proxy;
public class TestProxyFactory { public TestProxyFactory() { }
public static void main(String[] args) {
IProxy target = new Represented();
IProxy proxy = (IProxy)(new ProxyFactory(target)).getProxyInstance();
proxy.delete();
}
} 동적 프 록 시 장단 점: 동적 프 록 시 대상 은 피 프 록 시 대상 과 같은 인 터 페 이 스 를 실현 할 필요 가 없습니다. 피 프 록 시 대상 의 모든 방법 에 프 록 시 방법 을 추가 할 필요 가 없습니다. 반사 류 Proxy 와 InvocationHandler 리 셋 인 터 페 이 스 를 통 해 이 루어 진 jdk 동적 프 록 시 는 의뢰 류 에 하나의 인 터 페 이 스 를 실현 해 야 합 니 다. 그러나 모든 종류의 인터페이스 가 있 는 것 은 아 닙 니 다.인 터 페 이 스 를 실현 하지 못 한 클래스 에 대해 서 는 이 방식 으로 동적 대 리 를 실현 할 수 없습니다.인터페이스 가 실현 되 지 않 은 클래스 를 위 한 동적 에이전트 가 필요 하 다 면 cglib 동적 대 리 를 사용 할 수 있 습 니 다.미 완성. 계속.
각종 IT 서적 목록 및 다운로드 링크https://blog.csdn.net/dh1027/article/details/89327978
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
STL 학습노트(6) 함수 객체모방 함수는 모두pass-by-value이다 함수 대상은 값에 따라 전달되고 값에 따라 되돌아오기 때문에 함수 대상은 가능한 한 작아야 한다(대상 복사 비용이 크다) 함수 f와 대상 x, x 대상에서 f를 호출하면:...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.