分享

总结:Ruby中的@ % # $等各种千奇百怪的符号的含义等 转

 ala咪s 2017-12-20
总结:Ruby中的@ % # $等各种千奇百怪的符号的含义等

初学RUBY时,一看各种稍微复杂一点的代码时很容易被RUBY各种约定的表示方法搞晕,这整理一下 。

(若标识符首位是小写字母或“_”,则该标识符就是局部变量或方法调用。)

(以大写字母([A-Z])开始的标识符是常数、类名或者模块名)

以@开始的变量是实例变量,它属于特定的对象。可以在类或子类的方法中引用实例变量。

若引用尚未被初始化的实例变量的话,其值为nil。Ruby的实例变量无须声明,每个实例变量都是在第一次出现时动态加入对象。Ruby的实例变量通常在方法中定义类声明——当在方法里声明实例变量时,该实例变量实际上属于该方法所在类的实例,而不是属于该方法。例如
  1. ?1234567891011121314151617 class Apple          # 定义第一个方法          def info1              # 输出实例变量@a              puts @a        end        # 定义第二个方法          def info2              # 为实例变量赋值              @a = "Hello";          end    end    # 创建Apple类实例      apple = Apple.new    # 调用方法      apple.info2      apple.info1
复制代码
以@@开始的变量是类变量。在类的定义中定义类变量,可以在类的特殊方法、实例方法等处对类变量进行引用/赋值:
  1. ?123456 class Foo   @@foo = 1  def bar     puts @@foo  endend
复制代码
类变量与常数的区别如下。

可以重复赋值(常数则会发出警告) 
不能在类的外部直接引用(在继承类中则可以引用/赋值) 
类变量与类的实例变量的区别如下。

可在子类中引用/赋值 
可在实例方法中引用/赋值 
可以把类变量看作一种被类、子类以及它们的实例所共享的全局变量。

  1. ?class Foo   @@foo = 1endclass Bar < Foo   p @@foo += 1          # => 2 endclass Baz < Bar   p @@foo += 1          # => 3 end
复制代码
  

模块中定义的类变量(模块变量)被所有包含该模块的类所共享。
  1. ?module Foo   @@foo = 1endclass Bar   include Foo   p @@foo += 1          # => 2 endclass Baz   include Foo   p @@foo += 1          # => 3 end
复制代码
  

以$开始的变量是全局变量,可以在程序的任何地方加以引用(因此需要特别留意)。全局变量无需变量声明。引用尚未初始化的全局变量时,其值为 nil。

  

%表示法(百分号表示法):
  1. %{String}  用于创建一个使用双引号括起来的字符串 
  2. %Q{String} 用于创建一个使用双引号括起来的字符串 
  3. %q{String} 用于创建一个使用单引号括起来的字符串 
  4. %r{String} 用于创建一个正则表达式字面值 
  5. %w{String} 用于将一个字符串以空白字符切分成一个字符串数组,进行较少替换 
  6. %W{String} 用于将一个字符串以空白字符切分成一个字符串数组,进行较多替换 
  7. %s{String} 用于生成一个符号对象 
  8. %x{String} 用于执行String所代表的命令 

  9. "%05d" % 123 &raquo; "00123"

  10. "%-5s: %08x" % [ "ID", self.id ] &raquo; "ID:200e1670"
复制代码
# 用来调用一个方法,




*号:

若左边最后一个表达式前带*的话,则将右边多余的元素以数组的形式代入这个带*的表达式中。若右边没有多余元素的话,就把空数组代入其中。
  1. ?*foo     = 1, 2, 3      # foo = [1, 2, 3] foo,*bar = 1, 2, 3      # foo = 1; bar = [2, 3]
复制代码
*用在方法定义中表示可变长的变量:

【FROM “ProgrammingRuby”】

Variable-Length Argument Lists 

But what if you want to pass in a variable number of arguments, or want to capture multiple arguments into a single parameter? Placing an asterisk before the name of the parameter after the ``normal'' parameters does just that.
  1. ?def varargs(arg1, *rest)     "Got #{arg1} and #{rest.join(', ')}"endvarargs("one") &raquo; "Got one and "varargs("one", "two") &raquo; "Got one and two"varargs "one", "two", "three" &raquo; "Got one and two, three"
复制代码
  1. ?irb(main):005:0> def call_back(*a) irb(main):006:1> a.each do |arg| irb(main):007:2*    puts  arg irb(main):008:2> endirb(main):009:1> end=> nilirb(main):011:0> call_back(["hello",99]) hello 99=> [["hello", 99]] irb(main):012:0> call_back(["hello",99],"hello",99) hello 99hello 99=> [["hello", 99], "hello", 99]
复制代码
  

  

其他用法:
  1. C:\Users\Administrator>irb
  2. irb(main):001:0> [1,2,3] * "hi"
  3. => "1hi2hi3"
  4. irb(main):002:0> [1,2,3] * ";"
  5. => "1;2;3"
  6. irb(main):003:0> [1,2,3] * 3
  7. => [1, 2, 3, 1, 2, 3, 1, 2, 3]
  8. irb(main):004:0> "hi" * 3
  9. => "hihihi"
复制代码

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多