DDR爱好者之家 Design By 杰米

代码块的序列调用
复制代码 代码如下:
def touch_down 
  yield [3, 7] 
  puts "touchdown!" 
end 
 
touch_down do |(first_down, second_down)| 
  puts "#{first_down} yards on the run" 
  puts "#{second_down} yards passed" 
end 
 
=> "3 yards on the run" 
=> "7 yards passed" 
=> "touchdown!" 

主要是说array在block中的使用

从array中取出元素
复制代码 代码如下:
args = [1, 2, 3] 
first, rest = args 
 
first 
=> 1 
 
rest 
=> [2, 3] 

之前只是清楚split序列的用法,没有注意到实际上,我们可以方便的得到剩余的序列。

Hash#fetch

复制代码 代码如下:
items = { :apples => 2, :oranges => 3 } 
=> items = {:apples=>2, :oranges=>3} 
 
items.fetch(:apples) 
=> 2 
 
items.fetch(:bananas) { |key| "We don't carry #{key}!"} 
=> We don't carry bananas! 

在散列的使用的时候,fetch可能会比检查是否存在值要方便一些。

创建代码段的散列
复制代码 代码如下:
smash = Hash.new { |hash, key| hash[key] = "a #{key} just got SMASHED!" } 
=> {} 
 
smash[:plum] = "cannot smash." 
=> {:plum=>"cannot smash."} 
 
smash[:watermelon] 
=> {:plum=>"cannot smash.", :watermelon=>"a watermelon just got SMASHED!"}

将代码段用于生产散列可以方便的保持一些未定义的初始值,特别是在斐波纳契计算中很适合(我没有看出来怎么用)

Array#sort_by
复制代码 代码如下:
cars = %w[beetle volt camry] 
=> ["beetle", "volt", "camry"] 
 
cars.sort_by { |car| car.size } 
=> ["volt", "camry", "beetle"] 

序列的sort_by方法用来对代码段的返回值排序,就如同对于Symbol#to_proc进行map或者sort

String#present"codetitle">复制代码 代码如下:
"brain".present"".present? 
=> false 

Rails的开发者可能对于blank?比较熟悉,然而对于present呢?实际上判断返回值是否正确这也是很好用的方法。

这里我确实想起来,对于find(:all)和find(:first)是否有返回值的判断的不同。还有一个

.exists?
.empty?
.blank?
.nil?

比较多见到吧

DDR爱好者之家 Design By 杰米
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
DDR爱好者之家 Design By 杰米

RTX 5090要首发 性能要翻倍!三星展示GDDR7显存

三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。

首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。

据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。