Programming Ruby 1.9学习笔记之一---Ruby的块(Block)
Programming Ruby 1.9学习笔记之一---Ruby的块(Block)
Ruby中的块是比较有意思的地方,块体现了Ruby灵活之处。块就是一些语句的集合,类似于匿名函数或回调函数。
一,块的声明
块的声明在函数调用之后,用{..}括起来,或do..end封装。{}一般用在单行语句上,do..end用在多行语句上。
(1..4).each{|v| print "#{v} "} #输出1 2 3 4
sum = 0(1..5).each do |v|name = 'smile' #name属于块内变量,其可视范围只能在块内。假设块外没有相同名称的变量.sum += v #sum在块内可见endp sum #输出15,sum已改变。p name #Error! name不可访问。
name = 'outside'sum = 0(1..5).each do |v;name| #name在";"之后,可以声明多个变量,用逗号隔开name = 'inside' #name属于块内变量,其可视范围只能在块内.假设块外没有相同名称的变量。sum += v #sum在块内可访问endp sum #输出15,sum已改变。p name #输出outside,没有变。
def threeTimeyieldyieldyieldendthreeTime{p 'Hello world!'}
def takeBlock(p1) if block_given? # 判断是否有块,如果在yield时,没有声明块,会出错,所以在这里作判断会好点。 yield(p1) #把p1传给块参数,既下面块声明中的s else p1 endendietakeBlock("no block") #输出"no block"takeBlock("no block") { |s| s.sub(/no /, '') } #输出"block"
def nTime i = yield #第一次调用时,返回块的值 (0..i).each {|v| yield(v)} # 此处yield也可以放在块中endnTime do |v| print "#{v} " if v 9 #yield调用时返回的数end#输出1 2 3 4 5 6 7 8 9
def nTime(n) (0..n).each {|v| yield(v)}endnTime(9) do |v| print "#{v} "end
class Array def find for i in 0...size value = self[i] return value if yield(value) end return nil endend[1, 3, 5, 7, 9].find {|v| v > 5 } #实现查找第一个大于5的数,输出7。
class ProcExample def pass_in_block(&action) #action以&开头,是一个Proc的实例 @stored_proc = action end def use_proc(parameter) @stored_proc.call(parameter) #调用Proc.call方法 endendeg = ProcExample.neweg.pass_in_block { |param| puts "The parameter is #{param}" }eg.use_proc(99) #>>The parameter is 99
def create_block_object(&block) block #直接返回,注意这里不用写&endbo = create_block_object { |param| puts "You called me with #{param}" }bo.call "cat" #=>You called me with cat
bo1 = lambda { |param| puts "You called me with #{param}" } #使用lambda函数,比较怪异的名字bo1.call "cat"bo2 = Proc.new { |param| puts "You called me with #{param}" } #使用Proc.new函数bo2.call "cat"bo3 = ->(param) {puts "You called me with #{param}" } #Ruby1.9后出现的bo3.call "cat"
def fun #不带参数的 yieldendproc = ->{p 'haha'}fun &proc#####def fun2(x) #带参数的 yield xendproc2 = ->(x){p x}fun2 1,&proc2