加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

ruby – 使用`Hash#fetch’在`Hash#[]`上的好处

发布时间:2020-12-16 19:58:34 所属栏目:百科 来源:网络整理
导读:我不知道在什么情况下我想使用Hash#fetch over Hash#[].是否有一个常见的情况在哪里会很好用? 解决方法 三大用途: 当值是强制性的时候,即没有默认值: options.fetch(:repeat).times{...} 你也会收到一个很好的错误信息: key not found: :repeat 当值可以
我不知道在什么情况下我想使用Hash#fetch over Hash#[].是否有一个常见的情况在哪里会很好用?

解决方法

三大用途:

>当值是强制性的时候,即没有默认值:

options.fetch(:repeat).times{...}

你也会收到一个很好的错误信息:

key not found: :repeat

>当值可以为nil或false,默认值为其他值时:

if (doit = options.fetch(:repeat,1))
  doit.times{...}
else
  # options[:repeat] is set to nil or false,do something else maybe
end

>当你不想使用默认的/ default_proc的一个散列:

options = Hash.new(42)
options[:foo] || :default # => 42
options.fetch(:foo,:default) # => :default

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读