麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 學院 > 開發設計 > 正文

[13年遷移] C# yAspectF,輕量級的aop實現,編入分離阻斷

2019-11-17 02:51:03
字體:
來源:轉載
供稿:網友

[13年遷移] C# yaspectF,輕量級的aop實現,編入分離阻斷

介紹一下AspectF這個東西,誕生于一位微軟mvp之手,介紹它首先要從c#說起,當引入了委托這個概念的時候,它也只是c++的函數指針的封裝而 已,但是后續陸續引入的lambda表達式,匿名方法,泛型,擴展方法語法糖,讓其一次又一次的升華,一切都是如此美妙,可以說如果我把泛型的封裝再做上 去,這個框架基本就可以代表近期c#的新特征的一個集合.在不用反射或者編譯優化,這些解釋器的手段,可以說c#應該是最好,抽象程度最高的高級語言了 (如果用的話就是java好,不過那些都是寫生澀的技術,所以java的企業級框架,如此的強大)public class AspectF{//泛型的封裝太麻煩,而且暫時用不到,故只根據需要做個string的//在AspectF上加入了前阻斷,并修改返回值,你要拋錯也是行的 public delegate string yson(string i); public delegate string yDelegate(yson work,string i); public yDelegate yChain = null; /// <summary> /// 如果方面在work前面返回值了不是null的值,那么阻斷,后面的話 /// </summary> [DebuggerStepThrough] public AspectF yCombine(yDelegate newAspectReturnDelegate) { if (this.yChain == null) { this.yChain = newAspectReturnDelegate; } else { yDelegate existingChain = this.yChain; yDelegate callAnother = (work,i) => existingChain((ii) => newAspectReturnDelegate(work,ii),i); this.yChain = callAnother; } return this; } [DebuggerStepThrough] public string yReturn(Func<string> work) { if (this.yChain == null) { return work(); } else { var returnValue = string.Empty; this.yChain((i) => {//每個yDelegate的匿名方法參數都再執行一次自己的work委托,同時加一個標識,說明是后執行,那么就不在執行這里的work委托,那么后修改返回值就出來了,而委托鏈之間,直接用它們自己的返回值了遞歸傳獲得的執行結果,由里到外的獲得結果,用來調用,比如work("根據返回值后修改",代表執行后的常量) if (i != null) {//判定泛型封裝用define(T) returnValue = i; return returnValue; } returnValue= work();//執行這個 return returnValue; },null);//泛型的話,這里傳入define(T)即可 return returnValue; } }} class PRogram { static void Main(string[] args) { Console.WriteLine("最后返回"+saaddsad()); } public static string saaddsad() { return AspectF.Define .aPointer() .bPointer() .yReturn(() => { var ddd="執行方法"; Console.WriteLine(ddd); return ddd; }); } } static class AspectFExt {//語法糖的擴展類,怎么用不到呢?好像只能系統的? public static AspectF aPointer(this AspectF aspect) { return aspect.yCombine((work,i) => { Console.WriteLine("a切點前"); string a= work("截斷改變"); Console.WriteLine("a切點后"+a); work("a"); return "da"; }); } public static AspectF bPointer(this AspectF aspect) { //一個需要(func<string>)的方法,判斷如果work指向底層,就執行一個空的 return aspect.yCombine((work,i) => { Console.WriteLine("b切點前"); string b = work(i);//不想改變就返回i參數即可,不要使用null Console.WriteLine("b切點后"+b); return "fsa"; }); } }還能實現執行后獲得返回值,然后改變,執行前改變,泛型封裝的話,委托和匿名方法的約束寫起來估計是比較煩的,也還有點小問題.,項目就用到前阻斷,并改變返回值,那就這樣吧,其實只要再執行一個work,然后給一個標識,就能實現后阻斷,然后根據返回值再修改并傳遞,修改一下yReturn方法就行了.小型項目就不需要去借助企業框架,雖然編入的方式只能手動,不過效率是大型框架不能比的如果我也能就鉆研一門語言,專心做一門學問,或者一項工藝,無疑是幸福的吧,有一天一定要把你們全部畫出來.也許最近的傷感就是項目的后臺要做完了,分離的日子越來越近了..C#不舍得啊..但是js又在等著我.我依然前行,因為有很多未知的奇跡在等著我.


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 国产88久久久国产精品免费二区 | 国产精品久久久不卡 | 国产精品一区视频 | 中文字幕亚洲视频 | 一级做受毛片免费大片 | 成人免费在线播放 | 狠狠一区二区 | 国产精品久久久久久久久久久天堂 | 亚洲成人福利在线观看 | 欧美成人国产va精品日本一级 | 亚洲视频精选 | 国产网站黄 | 在线成人免费网站 | 成人一级片毛片 | 国产成人av一区 | 亚州精品国产 | 国产精品久久久久久久亚洲按摩 | 日本在线国产 | 国产jjizz一区二区三区视频 | 国产精品久久久久久一区二区三区 | 天天干天天碰 | av在线在线 | 成人区精品一区二区婷婷 | 欧美www| 亚洲福利在线观看视频 | 免费国产成人高清在线看软件 | 午夜伦情电午夜伦情电影 | 黄色av免费| 72pao成人国产永久免费视频 | 毛片成人| 国产伊人色 | 黄色网址进入 | 羞羞的视频 | 免费观看一级黄色片 | 色婷婷久久久亚洲一区二区三区 | 成年免费看 | 黄色大片在线免费看 | 成人毛片免费视频 | 国产精品久久久久久久久岛 | 免费在线中文字幕 | 久久久久久久免费看 |