草庐IT

HASH_ALGORITHM

全部标签

ruby-on-rails - Rails 3.1 中的 Rails.cache 错误 - TypeError : can't dump hash with default proc

我在3.1.0.rc4(ruby1.9.2p180(2011-02-18修订版30909)[x86_64-darwin10])上遇到Rails.cache方法问题。该代码在2.3.12(ruby1.8.7(2011-02-18补丁级别334)[i686-linux],MBARI0x8770,RubyEnterpriseEdition2011.03)上的同一应用程序中运行良好,但在升级后开始返回错误。我还没弄明白为什么。当尝试缓存具有多个作用域的对象时似乎会发生错误。此外,无论有多少范围,使用lambda的任何范围都会失败。我曾因这些模式而失败:Rails.cache.fetch("ke

ruby - 将 ruby​​ hash .default 设置为列表

这个问题在这里已经有了答案:Strange,unexpectedbehavior(disappearing/changingvalues)whenusingHashdefaultvalue,e.g.Hash.new([])(4个答案)关闭6年前。我以为我理解了默认方法对哈希的作用...如果键不存在则给它一个默认值:irb(main):001:0>a={}=>{}irb(main):002:0>a.default=4=>4irb(main):003:0>a[8]=>4irb(main):004:0>a[9]+=1=>5irb(main):005:0>a=>{9=>5}一切顺利。但是如果我

ruby - hash ['key' ] 到 Ruby 中的 hash.key

我有一个散列foo={'bar'=>'baz'}我想调用foo.bar#=>'baz'我的动机是将activerecord查询重写为原始sql查询(使用Model#find_by_sql)。这将返回以SELECT子句值作为键的散列。但是,我现有的代码依赖于object.method点表示法。我想做最少的代码重写。谢谢。编辑:看来Lua有这个功能:point={x=10,y=20}--Createnewtableprint(point["x"])--Prints10print(point.x)--Hasexactlythesamemeaningaslineabove

ruby - 在 Ruby 中,有没有办法使用类似 hash.each_with_index do |[k,v], i| 的方法?

否则就需要h={:a=>1,:b=>2.2}h.each_with_indexdo|pair,i|k=pair[0];v=pair[1]pk,v,iend并以这种方式设置k和v似乎有点笨拙。它可以更简单还是类似h.each_with_indexdo|[k,v],i|? 最佳答案 事实上,是的!使用括号:h={:a=>1,:b=>2.2}h.each_with_indexdo|(k,v),i|pk,v,iend 关于ruby-在Ruby中,有没有办法使用类似hash.each_with_i

ruby - 什么时候在 Ruby 中使用 Struct 而不是 Hash 更好?

RubyStruct允许使用一组访问器生成实例:#CreateastructurenamedbyitsconstantCustomer=Struct.new(:name,:address)#=>CustomerCustomer.new("Dave","123Main")#=>#这看起来方便且功能强大,但是,哈希的作用非常相似:Customer={:name=>"Dave",:address=>"123Main"}在哪些现实情况下我应该更喜欢Struct(以及为什么),选择其中一个有哪些注意事项或陷阱? 最佳答案 就我个人而言,当我想

ruby 风格 : How to check whether a nested hash element exists

考虑存储在散列中的“人”。两个例子是:fred={:person=>{:name=>"Fred",:spouse=>"Wilma",:children=>{:child=>{:name=>"Pebbles"}}}}slate={:person=>{:name=>"Mr.Slate",:spouse=>"Mrs.Slate"}}如果“person”没有任何child,则“children”元素不存在。所以,对于Slate先生,我们可以检查他是否有parent:slate_has_children=!slate[:person][:children].nil?那么,如果我们不知道“slat

ruby - Ruby 中的 to_s 与 to_str(以及 to_i/to_a/to_h 与 to_int/to_ary/to_hash)

我正在学习Ruby,我看到了一些让我有点困惑的方法,特别是to_s与to_str(同样,to_i/to_int,to_a/to_ary,&to_h/to_hash).我读到的内容解释说,较短的形式(例如to_s)用于显式转换,而较长的形式用于隐式转换。我真的不明白to_str实际是如何使用的。to_str会定义字符串以外的东西吗?你能给出这个方法的实际应用吗? 最佳答案 首先请注意,所有这些都适用于每对“短”(例如to_s/to_i/to_a/to_h)与“long”(例如to_str/to_int/to_ary/to_hash)强

ruby - 什么时候在 Ruby 中使用 Struct 而不是 Hash?

我没有太多的编程经验。但是,对我来说,Struct似乎有点类似于Hash。Struct可以做什么?有没有什么Struct可以做而Hash不能做的?google了一下,Struct的概念在C中很重要,但我对C了解不多。 最佳答案 结构在以下方面不同于使用HashMap(除了代码的外观):结构具有一组固定的属性,而您将新键添加到散列。调用结构实例上不存在的属性将导致NoMethodError,而从哈希中获取不存在的键的值只会返回nil。不同结构的两个实例永远不会相等,即使结构具有相同的属性并且实例具有相同的值(即Struct.new(:

ruby - 如何找到最大值hash的key?

我有以下哈希{"CA"=>2,"MI"=>1,"NY"=>1}如何使用ruby​​返回最大键值对?我希望它返回“CA” 最佳答案 这将根据哈希元素的值返回最大哈希键值对:deflargest_hash_key(hash)hash.max_by{|k,v|v}end 关于ruby-如何找到最大值hash的key?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/6040494/

ruby - 可以在 Hash each 循环中访问索引吗?

我可能遗漏了一些明显的东西,但是有没有办法在每个循环的哈希中访问迭代的索引/计数?hash={'three'=>'one','four'=>'two','one'=>'three'}hash.each{|key,value|#anywaytoknowwhichiterationthisis#(withouthavingtocreateacountvariable)?} 最佳答案 如果您想知道每次迭代的索引,您可以使用.each_with_indexhash.each_with_index{|(key,value),index|...