码迷,mamicode.com
首页 > Windows程序 > 详细

C#下Hashtable和Dictionary之间的差别

时间:2018-10-19 23:39:53      阅读:192      评论:0      收藏:0      [点我收藏+]

标签:个人   利用   算法   sync   排序   行数据   测试   tps   读取   

Hashtable和Dictionary都是.Net下的表示键值对的集合,那么我们在使用中该选择Hashtable还是Dictionary?下边我们看看他们之间的区别:
1、Dictionary<K,V>在使用中是顺序存储的,而Hashtable由于使用的是哈希算法进行数据存储,是无序的。
2、Dictionary的key和value是泛型存储,Hashtable的key和value都是object
3、Dictionary是泛型存储,不需要进行类型转换,Hashtable由于使用object,在存储或者读取值时都需要进行类型转换,所以比较耗时
4、单线程程序中推荐使用 Dictionary, 有泛型优势, 且读取速度较快, 容量利用更充分。多线程程序中推荐使用 Hashtable, 默认的 Hashtable 允许单线程写入, 多线程读取, 对 Hashtable 进一步调用 Synchronized() 方法可以获得完全线程安全的类型.
而 Dictionary 非线程安全, 必须人为使用 lock 语句进行保护, 效率大减。
5、在通过代码测试的时候发现key是整数型Dictionary的效率比Hashtable快,如果key是字符串型,Dictionary的效率没有Hashtable快。
对于如何进行选择,个人倾向于使用Dictionary,原因是:
1、Dictionary是可排序的,Hashtable如果想排序还需要采用别的方式进行
2、Dictionary有泛型优势,效率要高
---------------------
作者:凡梦_
来源:CSDN
原文:https://blog.csdn.net/mpegfour/article/details/78725768
版权声明:本文为博主原创文章,转载请附上博文链接!

C#下Hashtable和Dictionary之间的差别

标签:个人   利用   算法   sync   排序   行数据   测试   tps   读取   

原文地址:https://www.cnblogs.com/asdyzh/p/9819690.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!