您现在的位置: 爱51代码网 >> 范文 >> 文章正文
A Hashmap中有10个数,B Hashmap中有10万个数。现在从A和B中取同一个数
A Hashmap中有10个数,B Hashmap中有10万个数。现在从A和B中取同一个数(假设都存在的),问哪个查询出来耗时更少,为什么?
耗时差不多,应为是hashmap,key是按照hash算法(摘要算法)保存的,不需要遍历
因为是hash查找。hash存储有一定的规则,存好后的数据,不用像list那样去遍历,会根据key来计算hash值存的地址。然后根据地址直接拿数据。不管你一个数据,还是十万数据都是一样。
HashMap取值的效率与数量无关,HashMap读取性能主要取决于放入HashMap中的key对象的hashCode方法的实现,即此方法返回值导致的Hash冲突的比例,冲突越多,性能越差
如果就单纯取值的话,两者的时间花费几乎没什么差别;如果考虑到冲突的话,10W的平均取值时间应该稍长一些
  • 上一篇文章:

  • 下一篇文章: 没有了
  • 最新文章 热点文章 相关文章
    maven如何加自定义的包
    redhat 2.6 (santigo 5.6) vsftp
    shell如何实现自动填写操作执行下
    linux shell 文件配置sh:color:
    shell script语法一定要加path吗
    SecureCRT如何访问虚拟机vmWare中
    C#如何读取WINDOWS的放大系数
    cximge的图如何存入数据库并提取
    DBGRID控件显示查询结果文本类型
    TChart控件如何把表中右边的系列
    maven如何加自定义的包
    redhat 2.6 (santigo 5.6) vsftp
    shell如何实现自动填写操作执行下
    linux shell 文件配置sh:color:
    shell script语法一定要加path吗
    SecureCRT如何访问虚拟机vmWare中
    C#如何读取WINDOWS的放大系数
    cximge的图如何存入数据库并提取
    DBGRID控件显示查询结果文本类型
    TChart控件如何把表中右边的系列
    spring MVC 解析xml失败The 
    mysql查询出数据后如何选择匹
    文件字节流是如何把字节转换
    To display the auto-config
    struts1如何获取前台页面的值
    maven如何加自定义的包
    Dispatcher initialization 
    java怎么随机生成24字节Byte
    spring如何动态注解任务调度
    highcharts服务器怎么自动端
     



    设为首页 | 加入收藏 | 网站地图 | 友情链接 |