亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C# > 正文

C# 反射(Reflection)的用處分析

2020-01-24 02:06:41
字體:
來源:轉載
供稿:網友

亂侃

       作為一名新手,一直沒有勇氣去寫一篇分享。原因有很多:諸如:自己水平有限、語言表達不準確、寫出的東西沒有一點技術點被人嘲笑。今天在公司聽了內部員工的一個分享,其中最重要的一點是:提升自身水平的最佳的途徑就是――交流。不管你是通過什么途徑,交流也好、整理成文字分享也好等等都是很好的方式。故此,今天獻丑寫一篇自己的心得分享,歡迎各路大神的指教!

   需求背景

     今天接到的需求里面有個這樣的需求,如下圖所示,需要打印出如Excel內容呈現的單據。

    動手操作第一版本

     而為了實現這個業務需要涉及三張表的數據。(存放單據的表、審核意見表、審核狀態表)
     三張表的關系:單據表1:1審核狀態表,單據表1:N審核意見表
     為了實現讓View頁面整潔,我定義了一個SpecialPrintModel類

public class SpecialPrintModel  {    /// <summary>    /// 供應商承擔    /// </summary>    public string SupplierUnderTaker { get; set; }    /// <summary>    /// 客戶訂單號    /// </summary>    public string CustomerSerialNumber { get; set; }        /// <summary>    /// 付款金額    /// </summary>    public decimal PayAmount { get; set; }    /// <summary>    /// 開戶行    /// </summary>    public string OpeningBank { get; set; }    /// <summary>    /// 收款單位    /// </summary>    public string CollectionMonad { get; set; }    /// <summary>    /// 銀行帳號    /// </summary>    public string BankAccount { get; set; }    /// <summary>    /// 經辦人    /// </summary>    public string ResponseiblePerson { get; set; }    /// <summary>    /// 分管領導    /// </summary>    public string Leader { get; set; }    /// <summary>    /// 財務審核    /// </summary>    public string FinanceApproval { get; set; }    /// <summary>    /// 財務經理審核    /// </summary>    public string FinanceManagerApproval { get; set; }    /// <summary>    /// 財務總監審核    /// </summary>    public string FinanceDirectorApproval { get; set; }    /// <summary>    /// CEO審核    /// </summary>    public string CEOApproval { get; set; }    /// <summary>    /// 流水號    /// </summary>    public string SerialNumber { get; set; }  }
public List<ShipSpecialPrintModel> GetTobePaidRecepit(ShipSpecialSearch search) {   List<ShipSpecialPrintModel> curiseShipModel = new List<ShipSpecialPrintModel>();   var toBePaidModel = persistant.GetTobePaidRecepit(search);//查找出待支付的單據表信息   ArrayList serialArray=new ArrayList();//定義一個流水號列表   toBePaidModel.ForEach((u) => { serialArr.Add(u.SerialNumber); });   var toBePaidComment = persistant.GetTobePaidRecepitComment(serialArr);//查找出待支付單據的審核意見表(1個單據對應多少審核意見)   foreach (var item in toBePaidModel)   {     ShipSpecialPrintModel temp = new ShipSpecialPrintModel()     {         SupplierUnderTaker = supplierUnderTaker;         CustomerSerialNumber = item.CustomerOrderNumber;         PayAmount = item.PayAmount;         OpeningBank = item.PayBank;         CollectionMonad = item.Payee;         ResponseiblePerson = item.Creator;         SerialNumber = item.SerialNumber;     };     curiseShipModel.Add(temp);   }    foreach (var curise in curiseShipModel)      {        foreach (var comment in toBePaidComment)        {          if (comment.SerialNumber == curise.SerialNumber)          {            if (comment.ApprovalLevel == (int)LevelType.BranchedLeader)            {              curise.Leader = comment.Creator;            }            else if (comment.ApprovalLevel == (int)LevelType.Finance)            {              curise.FinanceApproval = comment.Creator;            }            else if (comment.ApprovalLevel == (int)LevelType.FinanceManager)            {              curise.FinanceManagerApproval = comment.Creator;            }            else if (comment.ApprovalLevel == (int)LevelType.ProjectDirector)            {              curise.FinanceDirectorApproval = comment.Creator;            }            else if (comment.ApprovalLevel == (int)LevelType.CEO)            {              curise.CEOApproval = comment.Creator;            }          }        }      }   return curiseShipModel }

    呵呵,上面的代碼基本完成了業務的需求,可是如果業務需要打印出CTO的名稱、CIO的名稱那在if else這邊加,雖然很簡單但是違背了開放-封閉的原則。故本人決定用反射去完成這if...else的事情。
因為if...else里面的判斷是當前的這筆單據的審核意見表的層級是不是跟SpecialPrintModel的字段所對應的層級相等,若相等則在對應字段寫入相對應的名稱。決定把SpecialPrintModel這個類修改下。
 
   動手操作第二版本

public class ShipSpecialPrintModel  {    /// <summary>    /// 供應商承擔    /// </summary>    public string SupplierUnderTaker { get; set; }    /// <summary>    /// 客戶訂單號    /// </summary>    public string CustomerSerialNumber { get; set; }        /// <summary>    /// 付款金額    /// </summary>    public decimal PayAmount { get; set; }    /// <summary>    /// 開戶行    /// </summary>    public string OpeningBank { get; set; }    /// <summary>    /// 收款單位    /// </summary>    public string CollectionMonad { get; set; }    /// <summary>    /// 銀行帳號    /// </summary>    public string BankAccount { get; set; }    /// <summary>    /// 經辦人    /// </summary>    public string ResponseiblePerson { get; set; }    /// <summary>    /// 分管領導    /// </summary>    [LevelAttribute(Level = 1)]    public string Leader { get; set; }    /// <summary>    /// 財務審核    /// </summary>     [LevelAttribute(Level = 2)]    public string FinanceApproval { get; set; }    /// <summary>    /// 財務經理審核    /// </summary>     [LevelAttribute(Level = 3)]    public string FinanceManagerApproval { get; set; }    /// <summary>    /// 財務總監審核    /// </summary>     [LevelAttribute(Level = 4)]    public string FinanceDirectorApproval { get; set; }    /// <summary>    /// CEO審核    /// </summary>     [LevelAttribute(Level = 5)]    public string CEOApproval { get; set; }    /// <summary>    /// 流水號    /// </summary>    public string SerialNumber { get; set; }  }  public class LevelAttribute : Attribute  {    public int Level { get; set; }  }
var toBePaidComment = persistant.GetTobePaidRecepitComment(ArrayList.Adapter(toBePaidModel.Select(u => u.SerialNumber).ToList()));  var specialPropertyInfo = (from property in typeof(CuriseShipSpecialPrintModel).GetProperties()                    where property.GetCustomAttributes(typeof(LevelAttribute), false).Count() > 0                    select property).ToList(); toBePaidModel.ForEach((item)=>{    ShipSpecialPrintModel temp = new ShipSpecialPrintModel()     {         SupplierUnderTaker = supplierUnderTaker;         CustomerSerialNumber = item.CustomerOrderNumber;         PayAmount = item.PayAmount;         OpeningBank = item.PayBank;         CollectionMonad = item.Payee;         ResponseiblePerson = item.Creator;         SerialNumber = item.SerialNumber;     };    var thisComments=toBePaidComment.Where(u=>u.SerialNumber =item.SerialNumber ).ToList();    thisComment.ForEach((cm)=>    {     if(cm.ApprovalLevel==(specialPropertyInfo.GetCustomAttributes(typeof(LevelAttribute),false).First() as LevelAttribute).Level)     {       cm.SetValue(model,cm.Creator,null);     }     }); })

    然而看到,propertyInfos那邊基本上每循環一次都需要去反射查找下元素,為了避免這樣的性能消耗,決定再修改一翻,定義一個字典去存儲SpecialPrintModel標有特性類的字段。

   動手操作第三版本

Dictionary<int, PropertyInfo> dic = new Dictionary<int, PropertyInfo>();  propertyInfos.ForEach((myProperty) => {      dic.Add((a.GetCustomAttributes(typeof(LevelAttribute),false).First() as LevelAttribute).Level,myProperty));   } ); comments.ForEach((cm) =>          {              if (dic.Keys.Contains(cm.ApprovalLevel))              {                dic[cm.ApprovalLevel].SetValue(model, cm.Creator, null);              }          });

   總體經過三次的修改,已經避免if...else的代碼。這樣而言,也比較適合后面比如再需要打印CTO審核的名稱。那樣只需要再Model類里面填寫字段與在字段上加上個特效。

  總結

      就像我同事說的那樣,做任務事情只要想想、多敲幾次。一些問題就不是問題了。好了,今天就寫到這里吧。晚安各位!

請您花一點時間將文章分享給您的朋友或者留下評論。我們將會由衷感謝您的支持!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
青青久久av北条麻妃黑人| 亚洲国产精品资源| 亚洲免费电影一区| 久久久久久亚洲精品中文字幕| 午夜精品美女自拍福到在线| 亚洲成年网站在线观看| 精品亚洲一区二区三区| 91香蕉嫩草影院入口| 成人性生交大片免费观看嘿嘿视频| 欧美性一区二区三区| 亚洲最新av在线网站| 亚洲国产成人久久综合| 久久国产精品影片| 最新日韩中文字幕| 欧美日韩免费在线| 久久久精品国产| 国产欧美一区二区三区久久人妖| 国内精品小视频| 欧美激情a∨在线视频播放| 日本一本a高清免费不卡| 色综合久久久久久中文网| 欧美日韩国产精品专区| 91免费看片网站| 国产精品久久久久久久7电影| 一区二区成人精品| 久99九色视频在线观看| 在线亚洲欧美视频| 在线视频一区二区| 日韩欧美在线国产| 欧美亚洲视频在线观看| 亚洲自拍小视频| 国产午夜精品一区二区三区| 国产成人综合一区二区三区| 亚洲成人av片在线观看| 国产精品嫩草影院久久久| 欧美日韩在线第一页| x99av成人免费| 成人黄色免费网站在线观看| 97在线视频免费播放| 这里只有精品在线观看| 97免费视频在线| 精品一区二区亚洲| 欧美日本高清视频| 日本免费一区二区三区视频观看| 国产亚洲精品91在线| 国产精品99久久久久久www| 日韩**中文字幕毛片| 国产欧美日韩综合精品| 欧洲永久精品大片ww免费漫画| 91免费看片在线| 国产日韩精品综合网站| 亚洲欧美激情精品一区二区| 色偷偷噜噜噜亚洲男人| 欧美多人乱p欧美4p久久| 亚洲一级黄色av| 色www亚洲国产张柏芝| 中文字幕不卡在线视频极品| 国产性猛交xxxx免费看久久| 欧美在线激情网| 久久久久久久久久久久久久久久久久av| 日韩av在线直播| 91在线视频成人| 中文字幕欧美日韩| 亚洲最新av网址| 国产免费亚洲高清| 亚洲第一黄色网| 成人激情视频免费在线| 2020欧美日韩在线视频| 国产精品久久久久一区二区| 久久成人国产精品| 在线观看国产精品日韩av| 久久免费少妇高潮久久精品99| 日韩成人xxxx| 亚洲国产欧美自拍| 中文字幕欧美日韩在线| 久久国产加勒比精品无码| 国产999精品久久久影片官网| 亚洲国产天堂网精品网站| 国产精品白丝av嫩草影院| 国产91在线视频| 国产一区二区三区中文| 91在线网站视频| 亚洲综合在线中文字幕| 国产精品久久久久av免费| 亚洲福利在线播放| 欧美在线观看网站| 91久久久久久久久久久| 欧美性xxxx| 青青久久av北条麻妃海外网| 亚洲天堂av电影| 欧美成人第一页| 亚洲欧美成人网| 亚洲免费精彩视频| 国产精品观看在线亚洲人成网| 91久久国产综合久久91精品网站| 91成人免费观看网站| 国产91|九色| 欧美视频中文字幕在线| 久久精品美女视频网站| 日韩中文字幕在线播放| 色婷婷综合久久久久中文字幕1| 欧美在线观看一区二区三区| 亚洲国产天堂久久综合| 日韩精品www| 97av在线播放| 亚洲国产中文字幕在线观看| 欧美野外猛男的大粗鳮| 国产日韩在线看片| 成人免费激情视频| 国外色69视频在线观看| 日韩电影中文字幕av| 国产精品va在线播放| 久久综合伊人77777尤物| 中文字幕不卡av| 亚洲日韩第一页| 97免费视频在线播放| 91禁外国网站| 欧美日韩国产精品专区| 伊人久久五月天| 国产欧美亚洲精品| 秋霞午夜一区二区| 亚洲片av在线| 国产精品极品美女粉嫩高清在线| 色综合亚洲精品激情狠狠| 亚洲一区二区免费在线| 在线视频免费一区二区| 欧美成人免费在线观看| 久久久av电影| 欧美日韩国产精品一区二区不卡中文| 亚洲精品美女在线观看播放| 永久免费看mv网站入口亚洲| 亚洲欧洲一区二区三区久久| 国产精品欧美亚洲777777| 91九色视频在线| 国产精品成人观看视频国产奇米| 国产精品久久久久久久久男| 国产精品自产拍在线观看中文| 久久艳片www.17c.com| 亚洲午夜未满十八勿入免费观看全集| 久久久国产在线视频| 欧美另类极品videosbest最新版本| 国产精品视频中文字幕91| 成人免费看片视频| 亚洲www永久成人夜色| 欧美精品福利视频| 91免费精品国偷自产在线| 欧美成aaa人片在线观看蜜臀| 庆余年2免费日韩剧观看大牛| 日韩欧美在线一区| 亚洲精品综合精品自拍| 国产成人97精品免费看片| 亚洲人成在线观看| 精品国内自产拍在线观看| 欧美影院成年免费版| 国产欧美va欧美va香蕉在线| 亚洲欧美一区二区精品久久久| 午夜精品久久久久久久久久久久久| 久久人人爽人人| 久久久精品亚洲| 国产欧美日韩丝袜精品一区| 日韩美女免费观看| 国产综合香蕉五月婷在线| 色偷偷av一区二区三区乱| 日本成人免费在线|