国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

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

值類型和引用類型在hashtable里面存取的性能比較

2019-11-18 16:55:20
字體:
來源:轉載
供稿:網友

首先定義兩個類:
 1    public interface ITest
 2    {
 3        void M();
 4    }
 5    public class Test1:ITest
 6    {
 7        public void M()
 8        {
 9        }
10    }
11   class Test
12        {
13            public Test()
14            {
15            }
16        } 首先,測試設置的速度hashtable.add()
 1static void Main(string[] args)
 2        {         
 3            Hashtable table = new Hashtable();
 4
 5            System.Diagnostics.Stopwatch stopWatch = new System.Diagnostics.Stopwatch();
 6            stopWatch.Start();
 7            for (int i = 0; i < CompareCount; i++)
 8            {
 9                table.Add(i,new Test());
10            }
11            stopWatch.Stop();
12           
13            for (int i = 0; i < CompareCount; i++)
14            {
15                Test o = table[i] as Test;
16            }
17          
18            string t1 = stopWatch.ElapsedTicks.ToString();
19         
20            Hashtable table1 = new Hashtable();
21            System.Diagnostics.Stopwatch stopWatch1 = new System.Diagnostics.Stopwatch();
22            stopWatch1.Start();
23            for (int i = 0; i < CompareCount; i++)
24            {
25                table1.Add(i, i);
26            }
27            stopWatch1.Stop();
28       
29            for (int i = 0; i < CompareCount; i++)
30            {
31                int o = (int)table1[i];
32            }
33          
34            string t2 = stopWatch1.ElapsedTicks.ToString();
35            Hashtable table2 = new Hashtable();
36            System.Diagnostics.Stopwatch stopWatch2 = new System.Diagnostics.Stopwatch();
37            stopWatch2.Start();
38            for (int i = 0; i < CompareCount; i++)
39            {
40                ITest test2 = new Test1();
41                table2.Add(i,test2);
42            }
43
44            stopWatch2.Stop();
45            for (int i = 0; i < CompareCount; i++)
46            {
47                ITest o = table2[i] as ITest;
48            }
49          
50            string t3 = stopWatch2.ElapsedTicks.ToString();
51            Console.WriteLine(t1);
52            Console.WriteLine(t2);
53            Console.WriteLine(t3);
54            Console.WriteLine(((double)Convert.ToInt64(t1)/Convert.ToInt64(t2)).ToString());
55            Console.WriteLine(((double)Convert.ToInt64(t3) / Convert.ToInt64(t2)).ToString());
56            Console.Read();
57           
58        }測試獲取的代碼
 1static void Main(string[] args)
 2        {         
 3            Hashtable table = new Hashtable();
 4        
 5            for (int i = 0; i < CompareCount; i++)
 6            {
 7                table.Add(i,new Test());
 8            }
 9           
10            System.Diagnostics.Stopwatch stopWatch = new System.Diagnostics.Stopwatch();
11            stopWatch.Start();
12            for (int i = 0; i < CompareCount; i++)
13            {
14                Test o = table[i] as Test;
15            }
16            stopWatch.Stop();
17            string t1 = stopWatch.ElapsedTicks.ToString();
18         
19            Hashtable table1 = new Hashtable();
20          
21            for (int i = 0; i < CompareCount; i++)
22            {
23                table1.Add(i, i);
24            }
25           
26            System.Diagnostics.Stopwatch stopWatch1 = new System.Diagnostics.Stopwatch();
27            stopWatch1.Start();
28            for (int i = 0; i < CompareCount; i++)
29            {
30                int o = (int)table1[i];
31            }
32            stopWatch1.Stop();
33            string t2 = stopWatch1.ElapsedTicks.ToString();
34            Hashtable table2 = new Hashtable();
35           
36            for (int i = 0; i < CompareCount; i++)
37            {
38                ITest test2 = new Test1();
39                table2.Add(i,test2);
40            }
41           
42            System.Diagnostics.Stopwatch stopWatch2 = new System.Diagnostics.Stopwatch();
43            stopWatch2.Start();
44            for (int i = 0; i < CompareCount; i++)
45            {
46                ITest o = table2[i] as ITest;
47            }
48            stopWatch2.Stop();
49            string t3 = stopWatch2.ElapsedTicks.ToString();
50            Console.WriteLine(t1);
51            Console.WriteLine(t2);
52            Console.WriteLine(t3);
53            Console.WriteLine(((double)Convert.ToInt64(t1)/Convert.ToInt64(t2)).ToString());
54            Console.WriteLine(((double)Convert.ToInt64(t3) / Convert.ToInt64(t2)).ToString());
55            Console.Read();
56           
57        }

測試結果 

Add

1)  調試(1)

數據類型

循環次數

執行時間

執行時間比例

int

100000

227960

1

class

100000

138122

0.6059

Interface

100000

103693

0.4549

 





 
調試(2

數據類型

循環次數

執行時間

執行時間比例

int

100000

282564

1

class

100000

156588

0.5542

Interface

100000

148623

0.5230






2) 

   運行(1)

數據類型

循環次數

執行時間

執行時間比例

int

100000

155927

1

class

100000

191537

1.2284

Interface

100000

127647

0.8186

    





 
運行(2)   

數據類型

循環次數

執行時間

執行時間比例

int

100000

151806

1

class

100000

222375

1.4649

Interface

100000

256467

1.6894

   





運行
(3)

數據類型

循環次數

執行時間

執行時間比例

int

100000

99465

1

class

100000

235016

2.3628

Interface

100000

201519

2.0260

 

 





從上面幾個表可以得出,在向
Hashtable里面添加數據的時候,當value為值類型的時候最快,interface次之,class

 

2. 查詢

  

1.       調試(1)

數據類型

循環次數

執行時間

執行時間比例

int

100000

52360

1

class

100000

71250

1.3608

Interface

100000

291566

5.5685

 

2.      



調試
(2)

數據類型

循環次數

執行時間

執行時間比例

int

100000

53645

1

class

100000

55679

1.0379

Interface

100000

310780

5.7932

 





  運行
(1)

數據類型

循環次數

執行時間

執行時間比例

int

100000

53013

1

class

100000

55414

1.0453

Interface

100000

282835

5.3352






  運行
(2)

數據類型

循環次數

執行時間

執行時間比例

int

100000

53647

1

class

100000

66768

1.2446

Interface

100000

204599

3.8138






  在查詢哈希表的時候,
int最快,class次之,interface比較慢


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 邵武市| 日土县| 乌兰县| 寿阳县| 桦川县| 游戏| 马边| 玛多县| 台东市| 海阳市| 怀仁县| 黑山县| 南安市| 内黄县| 佛冈县| 锡林浩特市| 屏南县| 胶州市| 隆子县| 宁城县| 容城县| 威宁| 东兰县| 屯昌县| 阿巴嘎旗| 金平| 安化县| 潮州市| 顺义区| 南阳市| 水城县| 宜宾市| 城口县| 仁化县| 灵宝市| 临夏县| 会昌县| 驻马店市| 柘荣县| 蕉岭县| 康保县|