Ruby對(duì)象初始化方法介紹
Ruby語(yǔ)言使用中完全面向?qū)ο蟮慕忉屝湍_本語(yǔ)言,其特點(diǎn)在于沒(méi)有函數(shù),只有各種方法。在這里,我們將會(huì)看到Ruby對(duì)象初始化的一些方法介紹。#t#
Ruby對(duì)象初始化之initalize方法
當(dāng)Ruby創(chuàng)建一個(gè)新對(duì)象時(shí),它總是會(huì)尋找一個(gè)名為 initialize 的方法并執(zhí)行它.因此,我們可以簡(jiǎn)單通過(guò)一個(gè)initialize方法向?qū)嵶兞恐屑尤肴笔≈?這樣一來(lái), inspect方法就有東西可說(shuō)了.
- ruby> class Fruit
- | def initialize
- | @kind = "apple"
- | @condition = "ripe"
- | end
- | end
- nil
- ruby> f4 = Fruit.new
- "a ripe apple"
將缺省的變?yōu)樾枰?/strong>
很多時(shí)候,缺省值不會(huì)有太多的意思.真的是缺省那樣的水果嗎?也許在創(chuàng)造水果的時(shí)候?qū)ζ漕愋妥饕笫莻€(gè)更好的辦法.要這樣做,我們就必須給initialize 方法加入一個(gè)正式的參數(shù).因?yàn)橐恍┎粫?huì)在此提及的原因,你向 new 傳遞的參數(shù)實(shí)際上是遞給了initialize.
- ruby> class Fruit
- | def initialize( k )
- | @kkind = k
- | @condition = "ripe"
- | end
- | end
- nil
- ruby> f5 = Fruit.new "mango"
- "a ripe mango"
- ruby> f6 = Fruit.new
- ERR: (eval):1:in `initialize'
: wrong # of arguments(0 for 1)
彈性的Ruby對(duì)象初始化
上面我們看到一旦一個(gè)參數(shù)被關(guān)聯(lián)到一個(gè) initialize 方法上,就無(wú)法在避免錯(cuò)誤產(chǎn)生的情況下將其省掉.如果希望考慮周全,我們可以在給了參數(shù)的情況下使用它,否則使用缺省值.
- ruby> class Fruit
- | def initialize( k="apple" )
- | @kkind = k
- | @condition = "ripe"
- | end
- | end
- nil
- ruby> f5 = Fruit.new "mango"
- "a ripe mango"
- ruby> f6 = Fruit.new
- "a ripe apple"
可以在任何方法內(nèi)使用缺省參數(shù),而不僅僅是initialize.參數(shù)表(argument list)必須以有缺省值的參數(shù)結(jié)尾.
有時(shí),提供多種Ruby對(duì)象初始化方法是有益的.雖然已超出本教程的范圍,但Ruby提供了對(duì)象映象(object reflection)和可變長(zhǎng)度的參數(shù)表(variable-length argument lists),這些都有效地促進(jìn)了方法重載.