`

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下载地址汇总.

    Secure_Hash_Algorithms.pdf

    autosar参考资料,Secure相关概念汇总 AES 加密算法,由NIST制定的标准,例如AES-128, AES-192 AsymmetricCryptography 使用两个不同值进行加密和解密的加密算法。非对称算法是基于很大数量的,并且很耗时。 ...

    [removed].hash知识汇总

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

    Hash_function.pdf

    autosar参考资料,Secure相关概念汇总 AES 加密算法,由NIST制定的标准,例如AES-128, AES-192 AsymmetricCryptography 使用两个不同值进行加密和解密的加密算法。非对称算法是基于很大数量的,并且很耗时。 ...

    125条常见的java面试笔试题大汇总

    HashMap和Hashtable的区别。 HashMap是Hashtable的轻量级实现(非线程安全的实现) ,他们都完成了Map接口 主要区别在于HashMap...Hashtable和HashMap采用的hash/rehash算法都大概一样,所 以性能不会有很大的差异。

    java面试笔试题大汇总.doc

    HashMap和Hashtable的区别。 HashMap是Hashtable的轻量级实现(非线程安全的实现),他们都完成了Map接口,主要区别在于HashMap...Hashtable和HashMap采用的hash/rehash算法都大概一样,所以性能不会有很大的差异。

    javascript跨域的方法汇总

    此文章学习借鉴了一些其他前端同学的文章,自己做了个实践总结 ...1.JSONP jsonp是利用script标签没有跨域限制的特性,通过在src的url的参数上附加回调函数名字,然后服务器接收回调函数名字并返回一个包含数据的回调...

    svelte-rollup-template:具有文件名哈希和HTML压缩功能的Svelte Rollup模板

    苗条的汇总模板Svelte汇总模板,带有文件名哈希和HTML最小化。 此模板通过在构建生产版本时对CSS / JS文件名进行哈希处理来补充官方的。 此外,模板HTML也已缩小。 此设置是的解决方案。 有关如何完成的操作,请参见...

    Linux渗透中文文章汇总合集

    Linux渗透中文文章汇总合集 a-link-to-an-attack.pdf burpsuite.pdf domain-invasion-metasploit.pdf domain-invasion-metasploit域入侵.pdf domain-invasion-of-Keimpx-Hash注入.pdf dump-windows-password-...

    Java面试题大汇总,2023年附答案解析.md

    在java中守护线程和本地线程区别 ... 如何通过反射调用对象的方法 如何进行单元测试 什么情况下会发生栈内存溢出 什么是Hash算法 什么是上下文切换 列举一些你知道的打破双亲委派机制的例子。为什么要打破

    java笔试题算法-spectra-hash:飞溅,这是参考文档

    hASH) 是一种明确的、独立于数据库的光谱标识符,就像 设计用作化学结构的唯一标识符一样。 它包含定义不同信息层的单独块,用破折号分隔。 例如,a 的完整 SPLASH 是splash10-0002-0900000000-b112e4e059e1ecf98c5f...

    2020 PG亚洲大会PPT汇总.zip

    2020年11月17日—11月20日,亚洲规格最高的PG技术盛会—...17、PostgreSQL源码解读 -- HASH表算法解析 18、PostgreSQL在数据仓库方面的优势与实践 19RDS PostgreSQL管控体系介绍 20、UniqueKey 让你的查询跑的更快

    redis常问面试题汇总

    (2)Redis 不仅仅支持简单的 key-value 类型的数据,同时还提供 list,set,zset,hash 等数据结构的存储。 (3)Redis 支持数据的备份,即 master-slave 模式的数据备份。 Redis 优势 (1)性能极高 – Redis ...

    MySQL性能优化易实现的MySQL优化方案汇总

     5、Hash索引与BTree索引区别(MyISAM与InnoDB不支持Hash索引)  (1)、BTree索引使用多路搜索树的数据结构,可以减少定位的中间过程;综合效率较高,默认使用的索引。  (2)、Hash索引使用Hash算法构建索引;...

    MySQL2023年高级面试题,中级面试题,大汇总.txt

    2,为什么索引结构默认使用B+Tree,而不是Hash,二叉树,红黑树? 3、MySQL里记录货币用什么字段类型好 4、数据库自增主键可能遇到什么问题。 5、从锁的类别角度讲,MySQL都有哪些锁呢? 6、索引失效情况? 7、优化...

    阿里巴巴/招行信用卡中心21届实习面试知识点汇总

    ②方法引用,可以进一步简化lambda表达式的书写,可以引用类的构造方法,静态方法,特定类的方法和某个对象的方法。③可以在接口中使用default定义默认方法和静态方法,引入默认方法方便了接口升级的维护,之前如果...

    Pass the SALT 2019PPT汇总(39份).zip

    .pdf', 'Improving your firmware security analysis process with FACT.pdf', 'Introduction to Osquery.pdf', 'JWAT… Attacking JSON Web Tokens.pdf', 'KILL MD5 demystifying hash collisions.pdf', 'Let’s ...

    面试:复习资料汇总

    面试复习资料汇总 计算机网络: 1. SSL(安全套接字层),TLS(传输层安全性) 对称加密算法:AES,DES非对称加密算法:RSA哈希算法:SHA MD5保证公钥的真实性:CA(证书颁发机构)A和B都各有一个公钥和一个私有密钥...

    C#各类集合汇总

    这些类提供了对栈(stack)、队列(queue)、列表(list)和哈希表(hash table)的支持。大多数集合类实现了相同的接口。 平常在工作中List集合是用的最多的,其次是Array(数组).今天整理一下各类形式的集合,不用就...

Global site tag (gtag.js) - Google Analytics