<Ruby元编程> 第二章 对象模型 类定义揭秘inside class definitions: class关键字更像一个作用域操作符,核心作用是可以在里面随时定义方法. [].methods.grep(/^re/):调用 出Array的所有以re开头的method. Monkeypatch:涉及全局修改,定义某个方法前应该仔细检查该类是否已有同名的方法. 实例对象存放在对象中,方法存放在类中. 类的真相:类本身也是对象.Ruby允许在运行时修改类的信息. Class.instance_me…
[C++11用于元编程的类别属性] 许多算法能作用在不同的数据类别; C++ 模板支持泛型,这使得代码能更紧凑和有用.然而,算法经常会需要目前作用的数据类别的信息.这种信息可以通过类别属性 (type traits) 于模板实体化时将该信息萃取出来. 类别属性能识别一个对象的种类和有关一个类别 (class) (或 struct) 的特征.头文件 <type_traits> 描述了我们能识别那些特征. 底下的例子说明了模板函数‘elaborate’是如何根据给定的数据类别,从而实体化某一特定的…
1.概述 模版元编程(template metaprogram)是C++中最复杂也是威力最强大的编程范式,它是一种可以创建和操纵程序的程序.模版元编程完全不同于普通的运行期程序,它很独特,因为模版元程序的执行完全是在编译期,并且模版元程序操纵的数据不能是运行时变量,只能是编译期常量,不可修改,另外它用到的语法元素也是相当有限,不能使用运行期的一些语法,比如if-else,for等语句都不能用.因此,模版元编程需要很多技巧,常常需要类型重定义.枚举常量.继承.模板偏特化等方法来配合,因此编写模版元…
1.概述 关于C++11模板元的基本用法和常用技巧,我在程序员2015年2月B<C++11模版元编程>一文(后称前文)中已经做了详细地介绍,那么C++11模版元编程用来解决什么实际问题呢,在实际工程中又该如何应用呢?本文将侧重介绍C++11模板的一些具体应用,向读者展示模版元编程的具体应用. 我们将展示如何通过C++11模版元来实现function_traits.Vairant类型和泛型bind绑定器.function_traits侧重于如何萃取可调用对象的一些元信息,Variant则是一种能…
第4章代码块blocks 基础知识 作用域:用代码块携带variables through scopes 通过传递block给instance_eval方法来控制作用域. 把block转换为Proc,lambda这样的可反复调用的对象.4.5 4.12基础 def a_method(a,b)   a + yield(a,b) end p a_method(2,1){|x, y| x * y}  #=>4 4.3代码块是闭包Closures 定义一个块时,它会获取当前环境中的绑定bingding,…
前几天看了Google Testing Blog上的一篇文章讲到C++因为没有反射机制,所以如何注册测试用例就成了一件需要各显神通的事情.从我的经验来看,无论是Google的GTest还是微软的LTM,都是通过宏来解决问题.但是对于Ruby之流的动态语言,这种事情太小菜一叠了.请看以下代码例子: class Test def test_001 puts 'test_001' end def test_002 puts 'test_002' end end t = Test.new test_me…
上个星期测试道的Monkey老师和我聊到测试用例参数过多的问题,其实这样的问题在我这里也同样经历过.比如我的测试用例必须面对不同的测试环境,每个环境有无数的参数,开发的最初阶段,因为参数少,所以就放在执行的命令行里,随着测试用例的不断增长,参数从4-5个增长到30多个,而且每个用例使用的参数也不完全相同,有使用ABCD的,有使用ADHJ的.另外有些参数想传一个数组进去,用命令行参数的方法就很难处理. 经过考虑,果断的使用配置文件来解决问题.选择配置文件当时有两个方案,一个是直接写成Ruby代码,…
元编程不过是编程--经典必读 作用域(绑定) 打破作用域门的方式 对象模型图 七条规则 法术手册 作用域(绑定) 改变作用域的关键字, 分别是module,class和def.我们称为作用域的门(scope gate) instance_eval以实例作用域执行代码 class_eval以类定义作用域执行代码 Kernel#eval方法,当前上下文中直接执行代码字符串 instance_eval class_eval 对象 单例方法 -- 类名(元类对象) 类方法 实例方法 表格是不精准.不完备…
一 对象模型 kernel Module Kernel.private_instance_methods.grep(/^pr/)   private method 1 如果一个方法接收者不是你自己,一定要指定一个接收者 2 私有方法 只能指定一个隐含接收者(可调超类的私有方法) 类本身是Class类的对象.类的名字是个常量 Class<Module,模块和类的名字扮演目录角色,按树形结构组织 include Module时 M被插入到祖先链中,在该类的正上方 二 方法 obj.send(:met…
Spell,也称pattern,idiom # Around Alias:从一个重新定义的方法中调用原始的,被重命名的版本. # old_reverse是未改变的原始方法,reverse/new_reverse是改变的方法. class String   def new_reverse     "x:#{old_reverse}"   end   alias_method :old_reverse, :reverse   alias_method :reverse, :new_reve…