草庐IT

哈希函数

全部标签

ruby-on-rails - SHA1 哈希值在我的 Rails 和 Cocoa 应用程序之间不匹配

我有一个Cocoa应用程序将一些数据连同该数据的SHA1哈希值一起发送到Rails应用程序,该应用程序验证数据和哈希值是否匹配,但它们不匹配。为了确保我已经记录了在Rails和Cocoa端散列到控制台的数据的十六进制版本,并且它们完全匹配。这是Cocoa部分:#import//...-(NSData*)dataOfSHA1Hash{unsignedcharhashBytes[CC_SHA1_DIGEST_LENGTH];CC_SHA1([selfbytes],CC_SHA1_DIGEST_LENGTH,hashBytes);return[NSDatadataWithBytes:hash

ruby - 为什么我不能使用新的 Ruby 1.9.2 哈希语法将整数用作键?

Ruby1.9.2中新的哈希语法意味着我可以执行以下操作:my_hash={a:1,b:2,c:3}...相当于:my_hash={:a=>1,:b=>2,:c=>3}好的,所以使用旧语法可以做到这一点(第一个键是一个整数):my_hash={1=>1,:b=>2,:c=>3}而且我发现甚至可以像这样混合使用新旧语法:my_hash={1=>1,b:2,c:3}因此,如果我们援引“最小惊奇原则”,人们会期望以下内容是合法的:my_hash={1:1,b:2,c:3}...但事实并非如此。它会产生一个语法错误:SyntaxError:(irb):40:syntaxerror,unexpe

ruby - 如何递归地用 ""替换 ruby​​ 哈希中的所有 nil 值?

str=""hash=Hash.from_xml(str)#=>{"a"=>{"b"=>{"c"=>nil}}}如何将散列中的所有nil替换为"",以便散列变为:{"a"=>{"b"=>{"c"=>""}}} 最佳答案 这里是递归的方法,不改变原来的hash。代码defdenilize(h)h.each_with_object({}){|(k,v),g|g[k]=(Hash===v)?denilize(v):v.nil??'':v}end示例h={"a"=>{"b"=>{"c"=>nil}}}denilize(h)#=>{"a"=>

ruby - 为什么 assert_equal 哈希的格式/语法与其他 assert_equals 不同?

我正在研究RubyKoans目前正在使用AboutHashes。到目前为止,assert_equals遵循特定的格式样式:assert_equalspaceexpected_valuecommaactualvalue(例如,assert_equal2,1+1)。但是AboutHashes中的test_creating_hashesdef有一个不遵循这种模式的assert_equal,如果我更改它以匹配该模式,它就会失败。具体来说:deftest_creating_hashesempty_hash=Hash.newassert_equal{},empty_hash#-->failsass

ruby - 在哈希中查找最低值

a={1=>["walmart","walmart.com",300.0],2=>["amazon","amazon.com",350.0],...}如何在其数组中找到浮点值最小的元素? 最佳答案 min_by可作为Enumerable模块中的方法使用。它获取Hash中所有值的数组,然后根据每个数组的最后一个元素选择最小值。a.values.min_by(&:last) 关于ruby-在哈希中查找最低值,我们在StackOverflow上找到一个类似的问题:

ruby - 如何使用 Ruby 中的变量访问符号哈希键

我有一个散列数组来为其编写通用检查器,因此我想传入要检查的键的名称。散列是用带有符号(冒号前缀)的键定义的。我不知道如何正确使用变量作为键。即使key存在于散列中,使用变量访问它也会导致nil。在IRB中,我这样做:>>family={'husband'=>"Homer",'wife'=>"Marge"}=>{"husband"=>"Homer","wife"=>"Marge"}>>somevar="husband"=>"husband">>family[somevar]=>"Homer">>another_family={:husband=>"Fred",:wife=>"Wilma"

ruby-on-rails - 如何删除哈希值为空的哈希键?

我正在使用RubyonRails3.2.13,我想删除对应哈希值为空的哈希键。也就是说,如果我有以下哈希{:a=>0,:b=>1,:c=>true,:d=>"",:e=>"",:f=>nil}那么生成的散列应该是(注意:0和true不被认为是空白){:a=>0,:b=>1,:c=>true}我该怎么做? 最佳答案 如果使用Rails你可以试试hash.delete_if{|key,value|value.blank?}或者如果只是Rubyhash.delete_if{|key,value|value.to_s.strip==''}

ruby - 究竟什么是匿名函数?

在我的一千行Ruby之旅中,我对匿名函数的概念感到非常困难。维基百科sayssomethingabout代码中有一些无名的灵魂,它服从于更高的秩序,但我的理解到此为止。或者换句话说,我将如何(当我理解它时)向我妈妈解释匿名函数? 最佳答案 匿名函数具有以下特征:它没有名字(因此是匿名的)内联定义在您不想要普通功能的开销/形式时使用没有明确引用超过一次,除非作为参数传递给另一个函数 关于ruby-究竟什么是匿名函数?,我们在StackOverflow上找到一个类似的问题:

ruby - 声明实例变量遍历哈希!

我想做以下事情:我想声明一个遍历字典的类的实例变量。假设我有这个散列hash={"key1"=>"value1","key2"=>"value2","key3"=>"value3"}并且我想将每个键都作为类的实例变量。我想知道我是否可以声明迭代该散列的变量。像这样:classMyClassdefinitialize()hash={"key1"=>"value1","key2"=>"value2","key3"=>"value3"}hash.eachdo|k,v|@k=vendendend我知道这行不通!我只是放了这段代码,看看你是否能更清楚地理解我想要什么。谢谢!

ruby - 如何创建两个哈希的交集?

我有两个哈希:hash1={1=>"a",2=>"b",3=>"c",4=>"d"}hash2={3=>"hello",4=>"world",5=>"welcome"}我需要一个散列,它包含两个散列中的公共(public)键:hash3={3=>"hello",4=>"world"}是否可以不用任何循环来实现? 最佳答案 hash3=hash1.keep_if{|k,v|hash2.key?k}这不会与问题中的代码产生相同的效果,而是会返回:hash3#=>{3=>"c",4=>"d"}散列的顺序在这里很重要。这些值将始终取自#ke