(1)类是一个加强的模块,因此全部类定义中的特性都一样适用于模块定义。ruby
(2)Ruby程序中老是存在一个当前对象:self,相似地,也总有一个当前类或模块存在,当定义一个方法时,该方法将成为当前类的一个实例方法。spa
(3)当经过class关键字打开一个类时,这个类就成为当前类。code
(4)Module#class_eval()方法(module_eval())方法能够在不知道类名的状况下打开一个类,例:对象
def add_method_to(a_class) a_class.class_eval do def m 'Hello' end end end
(5)类变量是以@@开头的变量,类变量与类实例变量不一样,它们能够被子类或者类的实例所使用继承
(6)单件方法,能够给当个对象添加方法,例:string
str = "Just a regular string" def str.title? self.upcase == self end str.title? #=>false str.methods.grep(/title?/) #=>["title?"] str.singleton_methods #=>["title?"]
(7)类方法的实质就是:它们是一个类的单件方法it
(8)Module#attr_reader()、attr_writer()、attr_accessor()能够用于生成读、写、二者都生成class
(9)eigenclass,获取一个eigenclass:变量
obj = Obejct.new eigenclass = class << obj self end eigenclass.class #Class
(10)eigenclass只有一个实例而且不能改被继承module
(11)到调用一个对象调用单件方法时,若是对象有eigenclass,先去eigenclass找,再向上找父类
(12)alias :new_name :old_name 能够用来给方法取别名。alias是个关键字,和他相似的还有一个Module#alias_method方法
(13)环绕别名:
(1)给方法定义一个别名
(2)重定义这个方法
(3)在新的方法中调用老的方法
(14)加上eigenclass后的类关系图:
因为图已经比较乱了,Class类的class箭头没有给出,Class.class #=> Class
从上图,能够看出不少的规律:
一个类(class指向Class)和它的eigenclass以及父类和父类的eigenclass老是存在一个四角关系
一个对象与他的类和对象的eigenclass老是存在一个三角关系
ruby真正的方法查询,实际上是先找接收者的eigenclass,在向上找父类
比较特殊的一点是BasicObject的eigenclass的父类是Class,因此全部的类按上面的方法查找方式,都会找到Class类,才会都有new方法和superclass(new方法和superclass方法是Class的实例方法)