草庐IT

c++ - QString 内置 64 位哈希函数?

全部标签

c - 我如何在 Ruby 的 C 扩展 API 上检索 'standalone' 符号

我想从C函数返回多个值,恕我直言,散列是一个不错的选择。我首先使用rb_intern('A_KEY')创建key,但扩展崩溃了。现在,我正在使用rb_str_new2,但我更喜欢符号。如何创建一个新符号,并在不引用类或方法的情况下使用它? 最佳答案 您需要使用ID2SYM宏将从rb_intern获得的标识符转换为ruby​​符号。尝试改变rb_intern('A_KEY')到ID2SYM(rb_intern('A_KEY')) 关于c-我如何在Ruby的C扩展API上检索'standal

ruby - 从较长的字符串生成短哈希字符串的最佳方法是什么

我正在尝试从Ruby中的较长字符串创建较短的非冲突字符串。最好的方法是什么?Base64编码MD5哈希?这是用例:loopdokey=short_hash("#{user_id}-#{timestamp}")breakif$redis.setnx(key,"0")end我不希望key太长。 最佳答案 我经常使用SHA与您的示例类似。它不能保证是唯一的,但通常足以满足大多数用途:require'digest/sha1'Digest::SHA1.hexdigest("#{user_id}-#{Time.now.to_i}-#{rand}

ruby - 在 ruby​​ 中合并两个排序列表的内置方法

我有两个Foo对象列表。每个Foo对象都有一个时间戳,Foo.timestamp。两个列表最初都按时间戳降序排列。我想以最终列表也按时间戳降序排序的方式合并Foo对象的两个列表。实现这个并不难,但我想知道是否有任何内置的Ruby方法可以做到这一点,因为我认为内置方法会产生最佳性能。谢谢。 最佳答案 这会起作用,但不会提供很好的性能,因为它不会利用事先已经排序的列表:list=(list1+list2).sort_by(&:timestamp)我不知道有任何内置函数可以满足您的需求。 关于

ruby - 如何检测递归数组和哈希?

如何检测包含递归结构的数组或散列,例如下面的a、b和c?递归数组的最简单实例a=[]a[0]=aa#=>[[...]]递归周期/深度不是一个b=[[],:foo]b[0][0]=bb#=>[[[...]],:foo]非根级别的递归c=[a,:foo]c#=>[[...],:foo] 最佳答案 我喜欢递归。这是一种不错的方法,遍历所有内容并保留您看到的对象的哈希值(用于快速查找)classObjectdefis_recursive?(known={})falseendendmoduleEnumerabledefis_recursive

Ruby - 可以将 block 作为参数作为实际 block 传递给另一个函数吗?

这就是我想要做的:defcall_block(in_class="String",&block)instance=eval("#{in_class}.new")puts"instanceclass:#{instance.class}"instance.instance_eval{block.call}end#---TESTEXAMPLE---#Thisoutputs"class:String"everytime"sdlkfj".instance_eval{puts"class:#{self.class}"}#Thiswillonlyoutput"class:Object"everyti

ruby - 内置的 Ruby 方法

如果有定义的内置ruby​​方法,是否总是使用内置方法更可取?如果我有这样的代码:ifi==0使用内置的ruby​​方法有什么好处?ifi.zero? 最佳答案 i.zero?仅在i为Numeric时有效对象。i=nili==0#=>falsei.zero?#NoMethodError:undefinedmethod`zero?'fornil:NilClass#from(irb):5#fromC:/Ruby200-x64/bin/irb:12:in`' 关于ruby-内置的Ruby方法,

ruby - 使用空数组意外行为初始化哈希

这个问题在这里已经有了答案:Strange,unexpectedbehavior(disappearing/changingvalues)whenusingHashdefaultvalue,e.g.Hash.new([])(4个答案)关闭3年前。我想用一个空的Array初始化一个Hash并且对于每个新键将特定值推送到该数组。这是我尝试做的:a=Hash.new([])#=>{}a[1]["asd"]a#=>{}a的预期输出是{1=>["asd"]}但这并没有发生。我在这里缺少什么?ruby版本:ruby2.0.0p598(2014-11-13revision48408)[x86_64-

ruby - 这种类似哈希/树状的构造称为什么?

我想创建一个介于散列和树之间的“Config”类。它只是用于存储全局值,可以有一个上下文。下面是我的使用方法:Config.get("root.parent.child_b")#=>"value"类可能如下所示:classConstructdefget(path)#splitpathby"."#searchtreefornodesenddefset(key,value)#splitpathby"."#createtreenodeifnecessary#settreevalueenddeftree{:root=>{:parent=>{:child_a=>"value",:child_b=

ruby - 如何将 Ruby 哈希 "up"中的属性移动一级

x={:name=>"John",:data=>{:physical=>{:age=>25,:weight=>150}}}我希望将数据的子属性向上移动一个级别(但不一定只是简单地展平所有属性)。在这种情况下,我基本上想将:physical属性“向上”移动一个级别。我正在尝试这个y=x[:data']y.each{|key|x[key]=y[key]}但是我得到...x=x.except(:data)=>{:name=>"John",[:physical,{:age=>25,:weight=>150}]=>nil}我在找...=>{:name=>"John",:physical=>{:a

ruby - 在 ruby​​ 中,方法和函数之间有区别吗

这个问题在这里已经有了答案:关闭11年前。PossibleDuplicate:Rubyfunctionsvsmethods我只是阅读了一些ruby​​文档,似乎以可互换的方式使用术语函数和方法,我只是想知道是否有任何区别?我正在查看的文档将其称为函数:defsaysomething()puts"Hello"endsaysomething这是一个方法:defmultiply(val1,val2)result=val1*val2putsresultend这可能是某种语义,但我想检查一下jt