前面一节的Fruit类有两个实变量,分别表述水果的类型和状态.直到为这个类写了一个定制的inspect方法,我们方才了解它不会对一个缺乏属性的水果做出合理的解释.幸运的是,Ruby提供了一种允许实变量总是被初始化的方法.
initalize方法
当Ruby创建一个新对象时,它总是会寻找一个名为initialize的方法并执行它.因此,我们可以简单通过一个initialize方法向实变量中加入缺省值,这样一来,inspect方法就有东西可说了.
ruby>classFruit
|definitialize
|@kind="apple"
|@condition="ripe"
|end
|end
nil
ruby>f4=Fruit.new
"aripeapple"
将缺省的变为需要的
很多时候,缺省值不会有太多的意思.真的是缺省那样的水果吗?也许在创造水果的时候对其类型作要求是个更好的办法.要这样做,我们就必须给initialize方法加入一个正式的参数.因为一些不会在此提及的原因,你向new传递的参数实际上是递给了initialize.
ruby>classFruit
|definitialize(k)
|@kind=k
|@condition="ripe"
|end
|end
nil
ruby>f5=Fruit.new"mango"
"aripemango"
ruby>f6=Fruit.new
ERR:(eval):1:in`initialize':wrong#ofarguments(0for1)
弹性的初始化
上面我们看到一旦一个参数被关联到一个initialize方法上,就无法在避免错误产生的情况下将其省掉.如果希望考虑周全,我们可以在给了参数的情况下使用它,否则使用缺省值.
ruby>classFruit
|definitialize(k="apple")
|@kind=k
|@condition="ripe"
|end
|end
nil
ruby>f5=Fruit.new"mango"
"aripemango"
ruby>f6=Fruit.new
"aripeapple"
可以在任何方法内使用缺省参数,而不仅仅是initialize.参数表(argumentlist)必须以有缺省值的参数结尾.
有时,提供多种初始化对象方法是有益的.虽然已超出本教程的范围,但Ruby提供了对象映象(objectreflection)和可变长度的参数表(variable-lengthargumentlists),这些都有效地促进了方法重载.