原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 、作者信息和本声明。否则将追究法律责任。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下载地址汇总.
### JavaScript的document方法汇总 在Web开发中,`document`对象是浏览器提供的核心对象之一,它代表当前加载的HTML文档,并提供了与文档交互的各种方法和属性。本文将详细介绍`document`对象的一些常用方法及其...
`window.name`和`hash`方法可以传递大量数据,但可能受到缓存或浏览器限制。在实际开发中,需要根据项目需求和安全考虑选择合适的方法。同时,现代浏览器还支持CORS(Cross-Origin Resource Sharing)跨域资源共享,...
而location.hash则可以用来获取或设置页面的标签值。比如http://domain/#admin的location.hash=”#admin”。利用这个属性值可以做一个非常有意义的事情。 [removed].hash简单应用 一、#的涵义 #代表网页中的一个位置...
哈希连接(Hash Join)是Oracle数据库中的一种高效连接方法,主要针对等值连接操作,其引入旨在解决嵌套循环连接(Nested Loop Join)中的大量随机读取问题以及排序合并连接(Sort-Merge Join)中的排序成本过高问题...
算法汇总是指在解决问题时,使用数学计算和数组问题的方法来解决问题。以下是算法相关汇总的知识点: 1. 连续子数组的问题和为某值的倍数问题 利用s[i,j]= s[0,j]-s[0,i]的概念,这里用到了余数的思想。如果上一个...
MySQL常见面试题汇总 MySQL 是一种关系型数据库管理系统,广泛应用于各种 web 应用程序中。在面试中,MySQL 相关的问题是非常常见的。下面是 MySQL 常见面试题汇总,涵盖索引相关、事务处理、锁机制、SQL 优化等多...
在性能考虑方面,通常使用hash表的方法(第二种方法)性能表现最佳,因为它基本保证了常数时间复杂度的操作,但是其缺点是可能会占用更多的内存空间,因为它需要额外的对象来作为hash表使用。对于大数据集,应进行...
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跨域的方法汇总,将介绍几种常用的技术和解决方案来突破浏览器同源策略的限制。 首先,最常用的跨域技术之一是JSONP(JSON with Padding)。JSONP的工作原理是利用`<script>`标签的跨域特性。当一个`...
"java中级面试题(自己汇总)" 本文总结了Java中级面试题,涵盖了集合、HashMap、HashSet、HashTable、ConcurrentHashMap、红黑树、Java 8对HashMap的优化、LinkedHashMap、TreeMap、IdentityHashMap等知识点。 ...
该方法使用一个空对象作为Hash表来记录哪些值已经出现过。遍历数组,如果当前值未作为对象的属性存在,则添加到结果数组中,并作为属性设置到对象里。由于对象属性的访问是基于哈希表结构的,其查找速度远快于数组...
在JavaScript中处理数组去重问题是前端开发中经常遇到的一个场景。因为JavaScript数组中可以存储各种...如果需要在老版本浏览器中实现数组去重,可以考虑使用扩展`Array.prototype`的方法,或者直接使用`hash`表方法。
### Java高频面试题汇总——Hashtable、HashMap、ConcurrentHashMap 区别详解 #### 一、概述 在Java编程中,`Hashtable`, `HashMap`, `ConcurrentHashMap`这三种集合类非常常见,它们提供了键值对的数据存储方式。...
本资源汇总了各大厂商护网面试题,涵盖了大量的IT知识点,包括go语言免杀shellcode、Windows Defender防御机制、卡巴斯基进程保护、Fastjson不出网、内存Webshell命令执行、域内渗透、正向shell方法、域内委派、...
磨片方法是通过磨掉芯片上的型号,对于一些不太常见的芯片来说,这种方法可能有效,但对于主流的芯片,通过管脚功能的分析仍然能够辨别出芯片型号。封胶方法通过封住PCB板及其上的元件,使得拆胶过程变得极其困难。...
**JavaScript BOM(浏览器对象模型)知识点汇总** 在JavaScript中,BOM(Browser Object Model)是浏览器提供的一系列接口,允许我们与浏览器环境进行交互,包括处理窗口、导航、历史记录、cookies、时间、弹出框等...
2. **成员变量最终化:** 除了`hash`成员外,其他成员变量均为`final`,一旦初始化就不能更改。 **好处:** - **安全性:** 避免字符串被意外修改,适用于多线程环境。 - **性能优化:** 基于不可变性,JVM能够对...