C#.net中提供了一個關鍵字 params,以前都不知道有這個關鍵字,有一次,同事看到我的幾版重載函數后,淡定地和我說了一句,哥呀,你可以用params,后來查了查,現在經常用習慣了,這不剛才又把之前寫的幾版都拿掉了,又用params重構了下。
那么,我就把params的用處,我經歷的這個過程說一下。
1 問題的需求 在客戶端,客戶經常會變動查詢的字段,前幾天還是根據4個關鍵字段去服務器查詢幾個模型呢,今天,又想加1個查詢字段。
根據4個關鍵字段的查詢方法:
public void GetPlansByInputControl(string planState, string contactno,DatePair dp) { string planStat = ""; switch (planState) { case "...": planStat = "..."; break; case "...": planStat = "..."; break; } plans = getPlansWithCondition(Convert.ToDateTime(dp.startValue), Convert.ToDateTime(dp.endValue), planStat, contactno); }調用的getPlansWithCondition方法為
PRivate List<MPartPlan> getMPartPlansWithCondition(DateTime dateTime, DateTime dateEndTime, string planStat, string contactNo) { var conditions = new CslSqlBaseSingleTable(); conditions.AddCondition("RequireStartDate", dateTime, DataCompareType.GreaterOrEqual); conditions.AddCondition("RequireStartDate", dateEndTime, DataCompareType.LessOrEqual); conditions.AddCondition("OrderCode", contactNo, DataCompareType.Equal); if (!string.IsNullOrEmpty(planStat)) { conditions.AddCondition("PlanState", planStat, DataCompareType.Equal); } return _cslMPartPlan.QueryListInSingleTable(typeof(MPartPlan), conditions); } }問題來了,當查詢再新加1個字段時,你難道還再重載一個版本嗎?
2 應用params
private List<MPartPlan> getMPartPlansWithCondition(DateTime dateTime, DateTime dateEndTime, string planStat, string contactNo,string newField);當C#提供了params后,當然不用,直接將getMPartPlansWithCondition改寫為如下
private List<MPartPlan> getMPartPlansWithCondition(params object[] queryConditions);{ queryConditions[0] queryConditions[1] queryConditions[2] queryConditions[3] queryConditions[4] //放到字典中dict sqlQuery(dict);}以后隨意添加查詢字段,只要修改下這個函數就行了,不用增刪重載版本?。。?/p>
客戶端調用,直接加一個字段就行
_bsl.GetPlansByInputControl(field1, field2,field3,field4,field5);3 總結
queryFun(params object[] objs),帶有這個參數的函數,只需要一個版本,這樣解決了因為個數不一致而導致的多個重載版本, 在客戶端調用時,將屬性參數一一列數即可。
新聞熱點
疑難解答