一、區別
在工作中經常遇到C#數組、ArrayList、List、Dictionary存取數據,其區別和優劣勢為:
初始化
數組:
int[] buff = new int[6];
ArrayList:
ArrayList buff = new ArrayList();
List:
List<int> buff = new List<int>();
Dictionary:
Dictionary<int,string> buff = new Dictionary<int,string>;
分析比較
從上面初始化的幾種類型可以看出,他們都屬於引用類型。其中數組、List、Dictionary在初始化的時候需要指定其元素類型,而ArrayList不需要指定類型。而在其中只有數組在初始化時設置了其大小。
數組:在初始化時必須指定其大小和類型,他在內存中是連續存儲的,所以可以看出數組的索引速度是非常快的。在確定了數組的長度和類型后,選擇數組存儲數據是比較好的選擇。不適合插入操作。
ArrayList:在初始化的時候不需要指定其大小和類型。他可以存儲不同的數據類型,但是在存取得過程中會引起裝箱和拆箱,降低了性能。插入操作方便。
List:在初始化的時候必須指定其類型,但是不需要指定大小,所以他不會像ArraryList那樣在存取過程中引起裝箱和拆箱操作。在類型相同的情況下,List和數組的性能相當。插入操作方便。
Dictionary:在初始化的時候也必須指定其類型,而且他還需要指定一個Key,並且這個Key是唯一的。正因為這樣,Dictionary的索引速度非常快。但是也因為他增加了一個Key,Dictionary占用的內存空間比其他類型要大。他是通過Key來查找元素的,元素的順序是不定的。下圖比較列表
二、目前我的使用
1.目前我用於接口中返回移動端所需要的數據,一般是先把數據放在DataTable中,然后再把DataTable放在Dictionary中,例如:
{ "result_status": true, "result_msg": "請求成功", "result_data": [{ "UserName": "推送測試", "Signer": 25, "Finish": 5, "Options": "", "SealWord": "A", "SignDate": "", "Sign": 0, "Flow": 5, "EnableSign": 1 }] }
2.后來Dictionary發現能放各種東西,而且是啥都能放,,,,於是開始往里面嵌套Dictionary
3.深入研究后需要往DataTable里插入信息,於是研究出先把DataTable轉成Dictionary再遍歷Dictionary再插入信息,還是先放轉Dictionary方法吧
/// <summary> /// 轉換Datatable為List<Dictionary<string, object>> /// </summary> /// <param name="dt">Datatable</param> /// <returns></returns> public static List<Dictionary<string, object>> ConvertToListDictionary(DataTable dt) { List<Dictionary<string, object>> list = new List<Dictionary<string, object>>(); foreach (DataRow dr in dt.Rows) { Dictionary<string, object> dic = new Dictionary<string, object>(); foreach (DataColumn dc in dt.Columns) { dic.Add(dc.ColumnName, dr[dc.ColumnName]); } list.Add(dic); } return list; }
然后遍歷一下:就可以往里面放信息了
foreach (var x in listdicData) { dt2 = DbHelperSQL.Query(sql2 + x["Id"] + orderBy2).Tables[0]; x.Add("data_Detail", dt2); }
放個效果例子吧還是:
{ "result_status": true, "result_Type": "總的合同付款審批台賬", "result_msg": "請求成功", "result_data": { "data_listMain": [{ "Id": 18, "AddDate": "2018-06-14T17:29:02.887", "AddUserId": 25, "ContractNum": "00002", "ContractAndName": "第二合同", "BargainMoney": 3000.00, "ContractXDMan": "2312", "BargainSignDate": "", "BargainFile": "", "FilesCount": 222.0, "SYmoney": 2778.0, "data_Detail": [{ "Id": 5, "Issue": "第5期", "Finish": "審批中" }, { "Id": 6, "Issue": "第6期", "Finish": "審批中" }] }, { "Id": 21, "AddDate": "2018-06-14T18:11:00.607", "AddUserId": 25, "ContractNum": "00001", "ContractAndName": "第一合同", "BargainMoney": 200.00, "ContractXDMan": "2", "BargainSignDate": "", "BargainFile": "", "FilesCount": 222.0, "SYmoney": -22.0, "data_Detail": [{ "Id": 4, "Issue": "第4期", "Finish": "審批完" }] }], "data_count": 2 } }
emm還有什么呢?后面再補充吧~
最后附加一個:Word轉Pdf方法(官方原生態方法,效果非常好)吧https://www.cnblogs.com/ggll611928/p/9019439.html