views:

105

answers:

1

I'm working through a book on Ruby, and the author used a slightly different form for writing a class initialization definition than he has in previous sections of the book. It looks like this:

class Ticket
  attr_accessor :venue, :date
  def initialize(venue, date)
    self.venue = venue
    self.date = date
  end
end

In previous sections of the book, it would've been defined like this:

class Ticket
  attr_accessor :venue, :date
  def initialize(venue, date)
    @venue = venue
    @date = date
  end
end

Is there any functional difference between using the setter method, as in the first example, vs. using the instance variable as in the second? They both seem to work. Even mixing them up works:

class Ticket
  attr_accessor :venue, :date
  def initialize(venue, date)
    @venue = venue
    self.date = date
  end
end
+8  A: 

Since the setter method has been defined by attr_accessor and thus does nothing but setting the variable, there is no difference between using the setter method and setting the variable directly.

The only upside to using the setter method is that if you should later change the setter method to do something more than setting the variable (like validate the input or log something), your initialize method would be affected by these changes without you having to change it.

sepp2k
+1 I've found that change notification isn't possible (or is difficult and undocumented) with `@venue`, only with `self.venue`. If anyone knows of a way to observe attribute-based setters, let me know ;)
Jim Schubert