加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

Ruby类:initialize self与@variable

发布时间:2020-12-16 19:59:56 所属栏目:百科 来源:网络整理
导读:有人可以解释在定义类时初始化“self”和使用@variables之间的区别吗? 这是一个例子 class Child Parent def initialize(self,stuff): self.stuff = stuff super() endend 那么在这种情况下,我不能用@stuff替换self.stuff?有什么不同?另外,super()只是意
有人可以解释在定义类时初始化“self”和使用@variables之间的区别吗?

这是一个例子

class Child < Parent
  def initialize(self,stuff):
    self.stuff = stuff
    super()
  end
end

那么在这种情况下,我不能用@stuff替换self.stuff?有什么不同?另外,super()只是意味着父应该继承它的父初始化方法是什么?

解决方法

一般来说,不,self.stuff = stuff和@stuff =的东西是不同的.前者在对象上进行一个方法调用stuff =,而后者直接设置一个实例变量.前者调用一个可能是public的方法(除非在类中特别声明为private),而后者则始终设置私有实例变量.

通常,它们看起来一样,因为在类上定义attr_accessor:stuff是很常见的. attr_accessor大致相当于以下内容:

def stuff
  @stuff
end

def stuff=(s)
  @stuff = s
end

所以在这种情况下,它们在功能上是一样的.然而,可以定义公共接口以允许不同的结果和副作用,这将使这两个“分配”明显不同:

def stuff
  @stuff_called += 1    # Keeps track of how often this is called,a side effect
  return @stuff
end

def stuff=(s)
  if s.nil?             # Validation,or other side effect. This is not triggered when setting the instance variable directly
    raise "Argument should not be nil"
  end
  @stuff = s
end

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读