Ruby基礎(chǔ)代碼經(jīng)驗(yàn)分享
Ruby語言的學(xué)習(xí)和其他編程語言一樣,首先要從基礎(chǔ)開始。在這里我們?yōu)榇蠹医榻B了一下Ruby基礎(chǔ)代碼中的BEGIN和END的編寫方式。#t#
Ruby基礎(chǔ)代碼之BEGIN 塊
BEGIN 塊中的代碼在所有代碼執(zhí)行之前執(zhí)行,Ruby 允許設(shè)置多個(gè) BEGIN 塊并按出現(xiàn)的順序執(zhí)行塊中的代碼。C# 程序員注意下面的代碼
- BEGIN
- {
- print "OnInit(object sender,
EventArgs args)\n" - }
- BEGIN
- {
- print "OnLoad(object sender,
EventArgs args)\n" - }
- print "Running"
上面的代碼看上去很美吧,可惜的是上面的代碼段會(huì)出現(xiàn) parse error,正確的代碼應(yīng)該是
- BEGIN{
- print "OnInit(object sender,
EventArgs args)\n"- }
- BEGIN{
- print "OnLoad(object sender,
EventArgs args)\n"- }
- print "Running"
正如上面的代碼段所呈現(xiàn)的,只有當(dāng)起始大括號(hào)和 BEGIN 標(biāo)識(shí)符位于同一行時(shí)塊內(nèi)的代碼才能得到正確的執(zhí)行。同時(shí) BEGIN 塊也不受任何控制結(jié)構(gòu)的影響,因?yàn)橹灰霈F(xiàn) BEGIN 塊就會(huì)得到執(zhí)行并且只執(zhí)行一次。
- i = 0
- while i < 10
- # 雖然處理循環(huán)結(jié)構(gòu)中,但 BEGIN
塊內(nèi)的代碼仍然只執(zhí)行一次- BEGIN{
- print "OnInit(object sender,
EventArgs args)\n"- }
- i += 1
- end
- if false
- # BEGIN 完全不受 if 的影響,
只要出現(xiàn) BEGIN 塊就會(huì)得到執(zhí)行- BEGIN{
- print "OnLoad(object sender,
EventArgs args)\n"- }
- end
- print "Running"
基于只要現(xiàn)出 BEGIN 就會(huì)得到執(zhí)行和 BEGIN 在所有代碼執(zhí)行之前執(zhí)行的原則,即使 BEGIN 塊前出現(xiàn)了代碼,該代碼仍然會(huì)等待 BEGIN 塊執(zhí)行之后再執(zhí)行。比如下面的代碼段輸出結(jié)果仍然是 OnInit - OnLoad - Running。
- print "OnLoad(object sender,
EventArgs args)\n"- BEGIN{
- print "OnInit(object sender,
EventArgs args)\n"- }
- print "Running"
Ruby基礎(chǔ)代碼之END 塊
END 塊與 BEGIN 塊相反,在所有代碼執(zhí)行之后執(zhí)行,多個(gè) END 塊時(shí)最先出現(xiàn)的 END 塊最后執(zhí)行。除此之外,END 塊雖然不受 while 的影響,但是可能通過 if 來控制 END 塊的執(zhí)行與否。比如下面代碼的輸出結(jié)果就是 Start - Load - Unload。
- if false
- END{
- # 永遠(yuǎn)不輸出
- print "Init"
- }
- end
- END{
- # 最后輸出
- print "Unload\n"
- }
- END{
- # 先于 Unload 輸出
- print "Load\n"
- }
- # 最先輸出
- print "Start\n"
以上就是我們?yōu)榇蠹医榻B的Ruby基礎(chǔ)代碼講解。