Ruby元编程技术

来自Dennis的知识库
2013年1月27日 (日) 10:49Dennis zhuang讨论 | 贡献的版本

跳转到: 导航搜索

目录

声明

  • 本Wiki上的任何文字信息均在GNU自由文档许可证1.3或更高版本下发布,如果用于任何商业用途都需经本人同意。任何转载都请注明出处。
  • 本Wiki上的内容来自本人的学习笔记,来源可能包括原创、书籍、网页、链接等,如果侵犯了您的知识产权,请与本人联系,我将及时删除。
  • 我的联系方式 killme2008@gmail.com

简介

读《Ruby元编程》的笔记

Open Class

class更像是作用域操作符,而不仅是类型声明语句。随时可以打开一个class定义或者覆写方法:

   #为String添加新方法
   class String
       def to_alphanumeric
            self.gsub /^[\w\s]/, ""
       end
   end

对象模型

  • 对象由一组实例变量和一个类的引用组成。
  • 对象的方法存在与对象所属的类中(从类的的角度来看,它们叫做实例方法)
  • 类本身是Class类的对象。类的名字不过是一个常量而已
  • Class类是Module的子类。一个模块基本上是由一组方法组成的包。类除了具有模版的特性之外,还可以被实例化(通过new方法)以及本组织为层次结构(通过superClass方法)
  • 常量像文件系统一样,是按照树形结构组织的。其中模块和类的名字扮演目录的角色,其他普通的常量则扮演文件的角色
  • 每个类都有一个祖先链,这个链从自己所属的类开始,向上直到BasicObject类结束
  • 当调用一个方法时,Ruby首先向右一步来到接受者所属的类,然后一直向上查找祖先链,直到找到该方法,或者到达链的顶端为止
  • 每当一个类包含一个模块时,该模块会被插入在祖先链中,位置在该类的正上方
  • 当调用一个方法时,接收者会扮演self的角色
  • 当定义一个模块时(或者类)时,该模块扮演self的角色
  • 实例变量永远被认定为self的实例变量
  • 任何没有明确指定接收者的方法调用,都当成调用self方法
   module M1
   end
   module M2
   end 
   module M3
   end
   class A
     include M1
    end
   class B < A
     include M2
     include M3
   end
  B.ancestors  => [B,M3,M2,A,M1,Object,Kernel,BasicObject]

Ruby object model.png

动态方法

  • 动态派发,利用send或者public_send(1.9加入)来动态调用函数
  • 动态定义方法,使用define_method来动态定义方法

Method Missing

  • method_missing包含在kernel模块中,默认抛出无法找到方法的error
  • 对象可以复写method_missing来动态响应方法调用,思考下,这其实就是消息传递。
  • 用途:
    • 幽灵方法:用来响应不曾明确的方法
    • 动态代理: 例如为web service创建本地动态代理
  • delegate标准库,委托模式
  • const_missing方法,用于常量
  • 注意事项:
    • 避免无限循环,适当调用super来终止循环。
    • 最好在一个白板对象上使用幽灵方法,避免重名,如何得到一个白板对象?使用undef_method方法来移除所有方法。
个人工具
名字空间

变换
操作
导航
工具箱