C#Dictionary使用記錄


一、區別

在工作中經常遇到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

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM