AOP PostSharp

复制代码
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using PostSharp.Laos;
using PostSharp;

namespace PostSharpApp
{
    [MyTrace(AttributeTargetMembers="Test*")]
    class Program
    {       
        static void Main(string[] args)
        {
            Test1();
            Test2();
            Foo();
            Console.ReadLine();
        }        
        static void Test1()
        {
            Console.WriteLine("Hello world! 1");
        }
        static void Test2()
        {
            Console.WriteLine("Hello world! 2");
        }
        static void Foo()
        {
            Console.WriteLine("Hello world! 3");
        }
    }

    [Serializable]
    class MyTrace : OnMethodBoundaryAspect
    {
        public override void OnEntry(MethodExecutionEventArgs eventArgs)
        {
            Console.WriteLine("Entering {0}", eventArgs.Method);
        }

        public override void OnExit(MethodExecutionEventArgs eventArgs)
        {
            Console.WriteLine("Exiting {0}", eventArgs.Method);
        }
    }
}
复制代码

 

posted @   shiningrise  阅读(151)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· .NET10 - 预览版1新功能体验(一)
历史上的今天:
2014-06-20 网店
2007-06-20 C#精髓-- GridView 72般绝技
// 侧边栏目录 // https://blog-static.cnblogs.com/files/douzujun/marvin.nav.my1502.css
点击右上角即可分享
微信分享提示