链表与Hash检索实测
测试环境:
Win7 SP1、8G内存、3.4GHz 4核
测试代码:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Reflection;
using System.Diagnostics; namespace FactoryMode
{
public class TestObject
{
public string memberString { get; set; }
public long memberBigInt { get; set; }
} [Serializable]
public class Program : MarshalByRefObject
{
static long TotalCount = ;
static long FisrtLv = ;
static long SecondLv = ;
static long ThirdLv = ; static void Main(string[] args)
{
//链表测试资源准备
var ObjectList = new List<TestObject>();
for (int i = ; i < TotalCount; i++)
{
var newTestObject = new TestObject();
newTestObject.memberString = i.ToString();
newTestObject.memberBigInt = i;
ObjectList.Add(newTestObject);
} //查找1
var stopWatch1 = Stopwatch.StartNew();
var result1 = ObjectList.Find(p => p.memberBigInt == SecondLv);
var lastElapsedTime1 = stopWatch1.ElapsedMilliseconds;
Console.WriteLine("Condition 1: {0} ms.", lastElapsedTime1);
Console.WriteLine("result1: {0}.", result1.memberString); //字典测试资源准备
var ObjectDictionary = new Dictionary<string, TestObject>();
for (int i = ; i < TotalCount; i++)
{
var newTestObject = new TestObject();
newTestObject.memberString = i.ToString();
newTestObject.memberBigInt = i;
ObjectDictionary.Add(newTestObject.memberString, newTestObject);
} //查找2
var stopWatch2 = Stopwatch.StartNew();
var result2 = ObjectDictionary[Convert.ToString(ThirdLv)];
var lastElapsedTime2 = stopWatch2.ElapsedMilliseconds;
Console.WriteLine("Condition 2: {0} ms.", lastElapsedTime2);
Console.WriteLine("result2: {0}.", result2.memberString); Console.Read(); }
}
}
测试结果:
链表检索:每50w 12ms;
Hash检索:0ms;
测试代码2:
//写入1
var stopWatch3 = Stopwatch.StartNew();
for (int i = ; i < FisrtLv; i++)
{
ObjectList[i].memberBigInt += ;
}
var lastElapsedTime3 = stopWatch3.ElapsedMilliseconds;
Console.WriteLine("Condition 3: {0} ms.", lastElapsedTime3); //写入2
var stopWatch4 = Stopwatch.StartNew();
for (int i = ; i < FisrtLv; i++)
{
ObjectDictionary[Convert.ToString(i)].memberBigInt += ;
}
var lastElapsedTime4 = stopWatch4.ElapsedMilliseconds;
Console.WriteLine("Condition 4: {0} ms.", lastElapsedTime4);
测试结果2:
链表写入:12ms;
Hash写入:143ms;(根据散列函数得到了新的存储位置,数据转移开销)
技术参考:http://blog.sina.com.cn/s/blog_7880b6e30100xi94.html。
注意点:
虽然Hash具有O(1)的数据检索效率,但它空间开销却通常很大,是以空间换取时间,所以Hashtable适用于读取操作频繁,写入操作很少的操作类型。
引申思考:
在实际的应用中,应避免将所有的常用、不常用的数据都放在同一个数据结构中,无论是使用自定义的内存结构或者是redis,都应该定时将过期数据放入二级缓存,为一级缓存瘦身。
在游戏服务器应用中,一个服务器应将数据分为内存数据、冷备数据,登陆时将冷备数据加载至内存(登陆较慢可容忍),单服热数据容量一般不会超过5w级别,数据结构的性能可接受。
在之前一个http短连接项目的应用中,每次协议都直接从redis读取数据,处理完毕之后写入redis,但是 redis 实际上没有冷数据,这样随着运行时间的推移,效率会越来越低。
链表与Hash检索实测的更多相关文章
- 数组、链表、Hash(转)
在程序中,存放指定的数据最常用的数据结构有两种:数组和链表. 数组和链表的区别: 1.数组是将元素在内存中连续存放. 链表中的元素在内存中不是顺序存储的,而是通过存在元素中的指针联系到一起. 2.数组 ...
- 洛谷P3832 [NOI2017]蚯蚓排队 【链表 + 字符串hash】
题目链接 洛谷P3832 题解 字符串哈希然后丢到hash表里边查询即可 因为\(k \le 50\),1.2操作就暴力维护一下 经复杂度分析会发现直接这样暴力维护是对的 一开始自然溢出WA了,还以为 ...
- 深入分析 Linux 内核链表--转
引用地址:http://www.ibm.com/developerworks/cn/linux/kernel/l-chain/index.html 一. 链表数据结构简介 链表是一种常用的组织有序数据 ...
- In-Memory:Hash Index
SQL Server 2016支持哈希查找,用户可以在内存优化表(Memory-Optimized Table)上创建Hash Index,使用Hash 查找算法,实现数据的极速查找.在使用上,Has ...
- 深入分析 Linux 内核链表
转载:http://www.ibm.com/developerworks/cn/linux/kernel/l-chain/ 一. 链表数据结构简介 链表是一种常用的组织有序数据的数据结构,它通过指 ...
- HashMap之Hash碰撞冲突解决方案及未来改进
说明:参考网上的两篇文章做了简单的总结,以备后查(http://blogread.cn/it/article/7191?f=wb ,http://it.deepinmind.com/%E6%80%A ...
- Java 集合 散列表hash table
Java 集合 散列表hash table @author ixenos 摘要:hash table用链表数组实现.解决散列表的冲突:开放地址法 和 链地址法(冲突链表方式) hash table 是 ...
- linux2.6内核链表
一. 链表数据结构简介 链表是一种常用的组织有序数据的数据结构,它通过指针将一系列数据节点连接成一条数据链,是线性表的一种重要实现方式.相对于数组,链表具有更好的动态性,建立链 ...
- Hash的一点测试
哈希表的学习与测试 以前写的hash都是碰运气的hash,就是乘上质数取模的那种,这样不能保证不碰撞,所以今天先写上几个双hush和链表的hash,并比较一下他们的速度,测试的话用洛谷上的“字符串哈希 ...
随机推荐
- 读书雷达 l 业务分析师(BA)篇
http://chuansong.me/n/412991951441 ThoughtWorks BA社区从2011年起就建立了BA书橱,根据大家的推荐选择了来自软件需求.商业分析.设计思维.软技能,以 ...
- android-配置虚拟机Virtual device
Android的应用程序是基于virtual device运行的,在运行一个android的应用程序之前先要配置要virtual device
- PAT---1013. Battle Over Cities (25)
这道题目的意思是:在战争时代,如果一个城市被敌人占领了,那么和该城市相连的道路都必须关闭,我们必须把剩下的城市(即不包括被敌人占领的城市)连接起来. 举个例子,我们有3个城市,C1,C2,C3,C1和 ...
- RichtextBox 行和列
获得光标所在的行号 获得光标所在的列号 设置光标到指定行号 设置光标到指定列号 http://www.huifangseo.com/blog/6/7.html 获得光标所在的行号和列号 方法1 int ...
- Oracle约束操作
约束的概念: 约束是在表中定义的用于维护数据库完整性的一些规则.通过为表中的字段定义约 束,可以防止将错误的数据插入到表中. 注意: 1.如果某个约束只作用于单独的字段,既可以在字段级定义约束,也可以 ...
- linux 进程综合指令
1. 查询当前机器运行的进程总数: ps -ef | wc -l ps -ef | grep httpd | wc -l 2. ulimit命令 表 1. ulimit 参数说明 选项 [option ...
- Response乱码的解决方法
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletExcept ...
- Freemarker学习中遇到的问题
在网上找到了尚学堂的视频,同时有书和源码等资料.但是在跟着练习的过程中,代码运行报了错: 2015-7-20 22:26:40 freemarker.log.JDK14LoggerFactory$JD ...
- jquery中Live方法不可用,Jquery中Live方法失效
jquery中Live方法不可用,Jquery中Live方法失效 >>>>>>>>>>>>>>>>> ...
- 如何快速学习bootstrap
bootstrap中文网http://www.bootcss.com/解决了我所有使用bootstrap的问题,从0开始,下面的全部链接都是该网站的子链接.例子http://v3.bootcss.co ...