手机
当前位置:查字典教程网 >脚本专栏 >ruby专题 >ruby 局部变量
ruby 局部变量
摘要:局部变量由小写字母或下划线(_)开头.局部变量不像全局和实变量一样在初始化前含nil值.ruby>$foonilruby>@foonilru...

局部变量由小写字母或下划线(_)开头.局部变量不像全局和实变量一样在初始化前含nil值.

ruby>$foo

nil

ruby>@foo

nil

ruby>foo

ERR:(eval):1:undefinedlocalvariableormethod`foo'formain(Object)

对局部变量的第一次赋值做的很像一次声明.如果你指向一个未初始化的局部变量,Ruby解释器会认为那是一个方法的名字;正如上面所见错误

信息的.

一般的,局部变量的范围会是

proc{...}

loop{...}

def...end

class...end

module...end

整个程序(除非符合上面某个条件)

下面的例子,define?是一个检查标识符是否已定义的操作符.如果已定义它将返回标识符的描述,否则返回nil.正如你所见的,bar的范围是

loop的局部变量;当loop退出时,bar无定义.

ruby>foo=44;printfoo,"n";defined?foo

44

"local-variable"

ruby>loop{bar=45;printbar,"n";break};defined?bar

45

nil

一个范围内的过程对象共享这个范围内的局部变量.这里,局部变量bar由main和过程对象p1,p2共享:

ruby>bar=0

0

ruby>p1=proc{|n|bar=n}

#<Proc:0x8deb0>

ruby>p2=proc{bar}

#<Proc:0x8dce8>

ruby>p1.call(5)

5

ruby>bar

5

ruby>p2.call

5

注意开始的"bar=0"不能省略;此赋值允许bar的范围被p1和p2共享.不然p1,p2将会分别生成并处理它们自己的局部变量bar,调用p2

也将导致"未定义局部变量或方法"错误.

过程对象的强大在于它们能被作为参数传递:共享的局部变量即使传递出原范围也仍然有效.

ruby>defbox

|contents=15

|get=proc{contents}

|set=proc{|n|contents=n}

|returnget,set

|end

nil

ruby>reader,writer=box

[#<Proc:0x40170fc0>,#<Proc:0x40170fac>]

ruby>reader.call

15

ruby>writer.call(2)

2

ruby>reader.call

2

Ruby对待范围的办法相当聪明.显然,上面例子里contents变量是由reader和writer共享的.我们也可以像上面那样创造多对使用box的

reader-writer;每一对共享一个contents变量,对之间不相干扰.

ruby>reader_1,writer_1=box

[#<Proc:0x40172820>,#<Proc:0x4017280c>]

ruby>reader_2,writer_2=box

[#<Proc:0x40172668>,#<Proc:0x40172654>]

ruby>writer_1.call(99)

99

ruby>reader_1.call

99

ruby>reader_2.call

15

【ruby 局部变量】相关文章:

Ruby中的变量学习总结

CentOS7下搭建ruby on rails开发环境

ruby 存取器 概念

实例讲解Ruby中的五种变量

ruby 简单例子

ruby 对象的初始化 方法

ruby 变量

ruby 类常量 解析

ruby 实变量

实例解析Ruby中的数值类型以及常量

精品推荐
分类导航