Google Groups no longer supports new Usenet posts or subscriptions. Historical content remains viewable.
Dismiss

difference between class and object methods

55 views
Skip to first unread message

Sagy Drucker

unread,
Jan 31, 2012, 7:29:00 AM1/31/12
to
hello
am i correct when i compare to java, and say:
object methods in ruby are equivalent object methods in java
and class methods in ruby are equivalent STATIC functions in java?

also,
class variables in ruby are equivalent to static variables in java?

thanks...
sagy... ( a very new ruby programmer )

Robert Klemme

unread,
Jan 31, 2012, 3:21:26 PM1/31/12
to
On 31.01.2012 13:29, Sagy Drucker wrote:
> am i correct when i compare to java, and say:
> object methods in ruby are equivalent object methods in java
> and class methods in ruby are equivalent STATIC functions in java?
>
> also,
> class variables in ruby are equivalent to static variables in java?

Yep, that's mostly correct. But you should rather not bother to use
class variables (those prefixed with @@) but instead should only use
instance variables of a class, e.g.

class X
def self.a_class_method
@@do_not_use_class_variables = 1
@but_use_class_instance_variables = 2
end
end

Reason is that class variables have weird scoping rules which can
produce strange effects.

Kind regards

robert

--
remember.guy do |as, often| as.you_can - without end
http://blog.rubybestpractices.com/

Rodrigo Kochenburger

unread,
Feb 1, 2012, 10:41:27 AM2/1/12
to
I'm not sure I'm entirely sure about this but I think comparing class level methods/variables to static methods is wrong. Please, correct me if I'm wrong.

Class methods are similar to static functions in java in terms of both being methods defined in what, conceptually, is a class. It is not really a static method because the interpreter will still do a dynamic dispatching of the method because ruby classes are still objects, instances of the class Class.

Class variables are variables that lives on the Class object and it is also accessible from all the instances and subclasses. If you change the value of the variable in a subclass, it will change the original value, affecting all classes and objects associated.

There is also the concept of class instance variable, which is a instance variable that resides in the singleton instance of the class.

More about this here: http://railstips.org/blog/archives/2006/11/18/class-and-instance-variables-in-ruby/

Danny Woods

unread,
Feb 2, 2012, 4:47:10 PM2/2/12
to
Sagy Drucker <sagy...@gmail.com> writes:

> hello
> am i correct when i compare to java, and say:
> object methods in ruby are equivalent object methods in java
> and class methods in ruby are equivalent STATIC functions in java?

Instance methods in Ruby can be considered semantically equivalent to
instance methods in Java.

Ruby's class methods are quite different. In Ruby, classes are
themselves objects that are available at runtime (yes, it's somewhat
circular), and so can have their own methods and variables. Classes are
instances of the class Class (e.g. String.class == Class; this ties up at
the end, where Class.class == Class).

Java's static methods and variables are not class methods in the same
sense. In Java, you cannot refer to 'super' in a static method, as
there is no 'this' (q.v. self, the current object; classes aren't objects in
Java. In a Ruby class method, 'self', refers to the class object).
Since there is no this/self, static methods in Java cannot be overridden in
subclasses (although they can be replaced by a static method with the
same signature). Being associated with a real object (the class), Ruby
class methods can be thought of as instance methods; they're just
methods on the class, not an individual instance of it.

Hope that helps.

Cheers,
Danny

Alec Ross

unread,
Feb 3, 2012, 6:51:38 AM2/3/12
to
In message <m3pqdwa...@mirror.lair>, Danny Woods
<danny...@yahoo.co.uk> writes
>Sagy Drucker <sagy...@gmail.com> writes:
>
>> hello
>> am i correct when i compare to java, and say:
>> object methods in ruby are equivalent object methods in java
>> and class methods in ruby are equivalent STATIC functions in java?
>
>Instance methods in Ruby can be considered semantically equivalent to
>instance methods in Java.
>
>Ruby's class methods are quite different. In Ruby, classes are
>themselves objects that are available at runtime (yes, it's somewhat
>circular), and so can have their own methods and variables. Classes are
>instances of the class Class (e.g. String.class == Class; this ties up at
>the end, where Class.class == Class).
>
>Java's static methods and variables are not class methods in the same
>sense.

But of course in there is an established terminology for "class methods"
and "static methods" (see, e.g.:

http://en.wikipedia.org/wiki/Class_method#Class_methods

), where, where, as it states there that "class methods are synonymous
with static methods" in Java and C++. And indeed also in C#, see. e.g.:

http://msdn.microsoft.com/en-us/library/aa645766%28v=vs.71%29.aspx ,

See also the comments on that Wikipedia entry in respect of Ruby in this
regard.

>In Java, you cannot refer to 'super' in a static method, as
>there is no 'this' (q.v. self, the current object; classes aren't objects in
>Java. In a Ruby class method, 'self', refers to the class object).
>Since there is no this/self, static methods in Java cannot be overridden in
>subclasses (although they can be replaced by a static method with the
>same signature). Being associated with a real object (the class), Ruby
>class methods can be thought of as instance methods; they're just
>methods on the class, not an individual instance of it.
>
>Hope that helps.
>
>Cheers,
>Danny


HTH,

Alec
--
Alec Ross
0 new messages