class和module很相似,类只不过是增加强了module,它比module多了三个方法:new()、allocate()和superclass()。

class 扩展module时用的两种方法:include和extend,当然它们是有区别的。

include包含一个module时,把它的实例方法和变量变成了class的实例方法和变量,这样类的祖先链中会出现这个module。

extend扩展一个module时,会把它的实例方法作为类方法加入到class,并且祖先链里不会出现这个module。

所有的类都继承自object类,object类又继承basicobject类,basicobject它是一个白板类。object类是ruby类和对象默认的根类,它的方法在所有子类中可用,它包含了kernel内核。

你可以在类中放入任何代码,类的定义也会返回最后一条语句的值。

例如:

result = class MyClass
  self
end
result # =>MyClass

当前类

不管处在ruby程序的哪个位置,总是存在一个当前对象:self。

class_eval():不需要使用class关键字就可以修改当前类。与Object#instance_eval()方法不同,instance_eval方法仅会修改self,而class_eval()会同时修改self和当前类。class_eval实际上是重新打开了该类,就像class关键字所做的一样。它比class关键字更灵活,可以对任何代表类的变量使用class_eval(),而class关键字只能使用常量。另外class关键字会打开一个新的作用域,这样将丧失当前绑定的可见性。

类实例变量

class MyClass

  @my_var

end

像这样定义在类中的实例变量,不同于对象的实例变量。它只是类对象的普通实例变量,仅可以被类本身所访问,而不能被类的实例或子类所访问。但以@@开头的类变量可以。

对象中有什么?

  1、实例变量:用obj.instance_variables查看,它们存放在对象中。

  2、方法:用obj.methods查看,它们存放在类中。

类也是对象,类名的风格是驼峰式的。

== 两个对象的值是否相等。支持类型转换。

equal? 方法用来判断2个对象是否是同一个对象,内存地址相同。

eql? 与==类似, 但是可以看做是更严格的==,不支持类型转换。

单件方法

str = "abc"
def str.title?
  self.upcase == self
end

这个title?是个单件方法。类方法其实就是类的单件方法。

Eigenclass

单件方法存在哪里,它不能存在于对象中,因为对象不是一个类,也不能存在类中,否则所有对象都能共享这个方法。答案是:eigenclass。它是一个对象特有的隐藏类。每个eigenclass只有一个实例,并且不能被继承,它是对象的单件方法的存活之所。

对象的eigenclass的superclass是对象的类。

类的eigenclass的superclass是类的superclass的eigenclass。

别名

通过关键字alias给方法取个别名:alias :new_method :origin_method

也可以用Module#alias_method()方法。