AspectJ构造函数强制工厂模式

时间:2012-04-24 02:36:58

标签: java aspectj factory-pattern

我想将对象返回从调用更改为构造函数

发件人

public class A  {

   public A(){
   }

   public String sayHello() {
    return "hello";
   }

   public String foo() {
      return "foo";
   }

}

TO

public class AWrapped extends A {

     private A wrapped;

     public AWrapped() {
       super();
     }


     public AWrapped(A pWrapped) {
        wrapped=pWrapped;
     }

     public String foo() {
       return wrapped.foo();
     }

     public String sayHello {
        return "gday mate";
     }

}

我想要做的是更改从通话中返回的对象

A a = new A();
a.sayHello() returns "gday mate"

a是AWrapped的实例

我知道这通常是通过工厂模式完成的,但我无法访问A的代码或创建新A的代码。并且有1000个地方可以创建A.

似乎Aspectj可能会做到这一点,但我不太了解它,如果AspectJ会做的诀窍如何绕过无限包装我需要知道它是从内部和方面构建的所以它不会包装再一次。

感谢您的帮助 乔恩

1 个答案:

答案 0 :(得分:6)

如果我理解你,你可以做到以下几点:

我创建了三个包:

package structure

  • aspect的aspectj和AWrapped.java
  • 未知的A.java(也可能是Bytecode但你必须使用Load Time Weaving
  • 主要测试A a = new A();

如果在A类上进行new()调用,MyAspect将返回AWrapped对象:

package aspectj;

import unknown.A;

@Aspect
public class MyAspect {

    @Pointcut("call(unknown.A.new(..)) && !within(aspectj..*)")
    public static void init(ProceedingJoinPoint pjp) {
    }

    @Around("init(pjp)")
    public Object initAdvice(ProceedingJoinPoint pjp) throws Throwable{
        Object ret = pjp.proceed();
        return new AWrapped((A) ret);
        }

}

进行测试:

package main;

import unknown.A;

public class Main {

    public static void main(String[] args) {
        A a = new A();
        System.out.println(a.sayHello());
    }
}

输出:

gday mate