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()方法。