`

Hash方法汇总

 
阅读更多
原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 、作者信息和本声明。否则将追究法律责任。http://blackanger.blog.51cto.com/140924/88709
一。给Hash添加默认值 :

h = {1,2,3,4}   #=> {1 => 2, 3 => 4}
h.default = 7
h[1]                #=>  2
h[3]                #=>  4
h[4]                #=>  7
h[5]                #=>  7



二。给Hash添加key-value对:
h = {}                     #=> {}
h.store("a",1)         #=> 1
h["a"]                     #=> 1
h.fetch("a")            #=> 1
h["b"] = 2               #=> 2
h["b"]                     #=> 2
p  h                        #=> {"a"=>1, "b"=>2}

store和[]= 方法是别名的关系,  fetch和[]方法是别名的关系。


三。清除Hash的key-value对:
h = {:a => 1, :b => 2}

删除全部的k-v对,有两种方法:
给hash赋空值
用clear方法 (这种方法更快一点)

shift方法随机删除k-v对。
h = {:a => 1, :b => 2, :c => 3}
h.shift             #=> [:a, 1]
h                     #=> {:b=>2, :c=>3}
a = h.shift       #=> [:c, 3]
a                     #=> [:c, 3]


delete, delete_if, reject,reject! 方法删除指定的k-v对:
h = {:a => 1, :b => 2}
h.delete(:a)                     #=> 1
h                                     #=> {:b=>2}
h = {:a => 1, :b => 2}      #=> {:a=>1, :b=>2}
h.delete_if {|k,v| v != 3}   #=> {}
h                                     #=> {}
h = {:a => 1, :b => 2}      #=> {:a=>1, :b=>2}
h.delete_if {|k,v| v != 1}   #=> {:a=>1}
h = {:a => 1, :b => 2}      #=> {:a=>1, :b=>2}
h.reject {|k,v| v!=2}          #=> {:b=>2}
h                                     #=> {:a=>1, :b=>2}

reject方法相当于dup.delete_if{}



四。颠倒Hash的k-v对。
h = {:a => 1,:b => 1}        #=> {:a=>1, :b=>1}
x = h.invert                      #=> {1=>:b}

invert方法可以颠倒Hash的键-值,可是因为Hash键的唯一性,可能会发生上例那样的数据丢失!

五。 Hash的迭代:
有each, each_key, each_value ,each_pair(each方法的别名)
不举例了。


六。检测Hash中的key,value:
   检测是否有key:
     has_key?(include? 别名, 只能判断key! ) ,key?, member?
   检测是否有value:
     has_value? value?

七。将散列转换为数组:

h = {:a => 1, :b => 2}
   h.to_a         #=> [[:a, 1], [:b, 2]]   转换为一个二维数组。
   h.keys         #=> [:a, :b]
   h.values      #=> [1,2]

   下面的方法有用点:
   h = {:a => 1, :b => '2', :c => 5}
   h.values_at(:a,:b)    #=> [1, “2”]    根据指定的key返回对应values的数组


八。根据条件选择key-value对:
 
h.detect {|k,v| v == "2"}             #=> [:b, "2"]

   detect和find是别名关系,是Enumerable模块里的方法,Hash类mixin这个模块,所以也可以用。select 方法,别名是find_all,可以返回多个匹配的k-v对:

h.select {|k,v| v.is_a?(Integer)}   #=> [[:a, 1], [:c, 5]]


九。 Hash的排序:
    可以直接用sort方法,不过会返回一个二维数组。
    值得注意的是,当Hash的key是Symbol类型的时候,sort方法会出错。


十。 合并两个Hash:
   使用merge方法,( merge!和update是别名关系 (thx Beck) )  。

h1 = {:a => 1, :b => 2}          #=> {:a=>1, :b=>2}
  h2 = {:b => 3, :d => 3}          #=> {:d=>3, :b=>3}
  h1.merge h2                         #=> {:a=>1, :d=>3, :b=>3}
  h2.merge h1                         #=> {:a=>1, :d=>3, :b=>2}

  注意看:b值的变化。
当然我们可以使用block来改变这一结局:
  h1.merge h2 do |k,old,new|
      old < new ? old : new
  end
#=> {:a=>1, :d=>3, :b=>2}
h1.merge h2 do |k,old,new|
    p old
    p new
end
#=>2
#=>3

(当然我们可以使用rails里active_support实现的revert_merge来实现上述效果)。

十一。 数组转换为Hash:
  当数组元素为偶数个数的时候:
 
arr = %w[a b c d]         #=> ["a", "b", "c", "d"]
    h = Hash[*arr]              #=> {"a"=>"b", "c"=>"d"}

   此时数组必须为偶数个元素。


十二。 当Hash的key是动态变化的时候:

x = [1,2]                  #=> [1, 2]
h = {x => 2}            #=> {[1, 2]=>2}
h[x]                         #=> 2
x[0] = 5                   #=> 5
h[x]                         #=> nil
h.rehash                 #=> {[5, 2]=>2}
h[x]                         #=> 2
分享到:
评论

相关推荐

    无线安全破解专用WPA-PSK_Hash_Table_DVD下载地址汇总.

    无线安全破解专用WPA-PSK_Hash_Table_DVD下载地址汇总.

    JavaScript的document方法汇总

    ### JavaScript的document方法汇总 在Web开发中,`document`对象是浏览器提供的核心对象之一,它代表当前加载的HTML文档,并提供了与文档交互的各种方法和属性。本文将详细介绍`document`对象的一些常用方法及其...

    javascript跨域的方法汇总.docx

    `window.name`和`hash`方法可以传递大量数据,但可能受到缓存或浏览器限制。在实际开发中,需要根据项目需求和安全考虑选择合适的方法。同时,现代浏览器还支持CORS(Cross-Origin Resource Sharing)跨域资源共享,...

    [removed].hash知识汇总

    而location.hash则可以用来获取或设置页面的标签值。比如http://domain/#admin的location.hash=”#admin”。利用这个属性值可以做一个非常有意义的事情。 [removed].hash简单应用 一、#的涵义 #代表网页中的一个位置...

    Oracle中hash join研究.pdf

    哈希连接(Hash Join)是Oracle数据库中的一种高效连接方法,主要针对等值连接操作,其引入旨在解决嵌套循环连接(Nested Loop Join)中的大量随机读取问题以及排序合并连接(Sort-Merge Join)中的排序成本过高问题...

    算法相关汇总1

    算法汇总是指在解决问题时,使用数学计算和数组问题的方法来解决问题。以下是算法相关汇总的知识点: 1. 连续子数组的问题和为某值的倍数问题 利用s[i,j]= s[0,j]-s[0,i]的概念,这里用到了余数的思想。如果上一个...

    MySQL常见面试题汇总

    MySQL常见面试题汇总 MySQL 是一种关系型数据库管理系统,广泛应用于各种 web 应用程序中。在面试中,MySQL 相关的问题是非常常见的。下面是 MySQL 常见面试题汇总,涵盖索引相关、事务处理、锁机制、SQL 优化等多...

    javascript数组去重的方法汇总

    在性能考虑方面,通常使用hash表的方法(第二种方法)性能表现最佳,因为它基本保证了常数时间复杂度的操作,但是其缺点是可能会占用更多的内存空间,因为它需要额外的对象来作为hash表使用。对于大数据集,应进行...

    c#操作Redis的5种基本类型汇总

    C#操作Redis的5种基本类型汇总 以下是C#操作Redis的5种基本类型的知识点总结: 一、String类型 * 简介:String是Redis最基本的类型,可以理解成与Memcached一样的类型,一个key对应一个value。String类型是二进制...

    常用大数据量,海量数据处理方法,算法总结

    Hash 函数的选择取决于数据类型,例如字符串、整数、排列等。碰撞处理有两种方法:open hashing(拉链法)和 closed hashing(开地址法)。 扩展的方法包括 d-left hashing,例如 2-left hashing,将哈希表分成长度...

    javascript跨域的方法汇总

    JavaScript跨域的方法汇总,将介绍几种常用的技术和解决方案来突破浏览器同源策略的限制。 首先,最常用的跨域技术之一是JSONP(JSON with Padding)。JSONP的工作原理是利用`&lt;script&gt;`标签的跨域特性。当一个`...

    java中级面试题(自己汇总)

    "java中级面试题(自己汇总)" 本文总结了Java中级面试题,涵盖了集合、HashMap、HashSet、HashTable、ConcurrentHashMap、红黑树、Java 8对HashMap的优化、LinkedHashMap、TreeMap、IdentityHashMap等知识点。 ...

    javascript数组去重的六种方法汇总

    该方法使用一个空对象作为Hash表来记录哪些值已经出现过。遍历数组,如果当前值未作为对象的属性存在,则添加到结果数组中,并作为属性设置到对象里。由于对象属性的访问是基于哈希表结构的,其查找速度远快于数组...

    js数组去重的方法汇总

    在JavaScript中处理数组去重问题是前端开发中经常遇到的一个场景。因为JavaScript数组中可以存储各种...如果需要在老版本浏览器中实现数组去重,可以考虑使用扩展`Array.prototype`的方法,或者直接使用`hash`表方法。

    Java高频面试题汇总(精华版).pdf

    ### Java高频面试题汇总——Hashtable、HashMap、ConcurrentHashMap 区别详解 #### 一、概述 在Java编程中,`Hashtable`, `HashMap`, `ConcurrentHashMap`这三种集合类非常常见,它们提供了键值对的数据存储方式。...

    各大厂商护网面试题汇总

    本资源汇总了各大厂商护网面试题,涵盖了大量的IT知识点,包括go语言免杀shellcode、Windows Defender防御机制、卡巴斯基进程保护、Fastjson不出网、内存Webshell命令执行、域内渗透、正向shell方法、域内委派、...

    加密方案汇总,汇总市面常见的几种加密方式对比,并对加密算法的安全等级和产品实现原理进行阐述

    磨片方法是通过磨掉芯片上的型号,对于一些不太常见的芯片来说,这种方法可能有效,但对于主流的芯片,通过管脚功能的分析仍然能够辨别出芯片型号。封胶方法通过封住PCB板及其上的元件,使得拆胶过程变得极其困难。...

    BOM知识点汇总

    **JavaScript BOM(浏览器对象模型)知识点汇总** 在JavaScript中,BOM(Browser Object Model)是浏览器提供的一系列接口,允许我们与浏览器环境进行交互,包括处理窗口、导航、历史记录、cookies、时间、弹出框等...

    Java基础知识点汇总

    2. **成员变量最终化:** 除了`hash`成员外,其他成员变量均为`final`,一旦初始化就不能更改。 **好处:** - **安全性:** 避免字符串被意外修改,适用于多线程环境。 - **性能优化:** 基于不可变性,JVM能够对...

Global site tag (gtag.js) - Google Analytics