Как использовать IInterceptor в Castle.DynamicProxy?

Я написал такой пример

Класс простого калькулятора:

public class Calculator
{
    public int Add(int a, int b)
    {
        return a + b;
    }
}

реализовал "IInterceptor", предоставленный DynamicProxy

 [Serializable]
public abstract class Interceptor : IInterceptor
{
    public void Intercept(IInvocation invocation)
    {
        ExecuteBefore(invocation);
        invocation.Proceed();
        ExecuteAfter(invocation);

    }
    protected abstract void ExecuteAfter(IInvocation invocation);
    protected abstract void ExecuteBefore(IInvocation invocation);
}

Создан класс Interceptor и унаследован от класса «Interceptor»

    public class CalculatorInterceptor : Interceptor
{
    protected override void ExecuteBefore(Castle.DynamicProxy.IInvocation invocation)
    {
        Console.WriteLine("Start");
    }

    protected override void ExecuteAfter(Castle.DynamicProxy.IInvocation invocation)
    {
        Console.WriteLine("End");
    }
}

но когда я использовал это НЕ работает !!!

static void Main(string[] args)
    {
        ProxyGenerator generator = new ProxyGenerator();
        Calculator c = generator.CreateClassProxy<Calculator>(new CalculatorInterceptor());
        var r = c.Add(11, 22);
        Console.WriteLine(r);
        Console.ReadKey();
    }

Я исключаю, чтобы увидеть что-то вроде этого:

START
33
END

но только шоу

33

Как я могу это исправить ?!

Ответы на вопрос(0)

Ваш ответ на вопрос