天天看點

Ruby 方法

Ruby 方法與其他程式設計語言中的函數類似。Ruby 方法用于捆綁一個或多個重複的語句到一個單元中。

方法名應以小寫字母開頭。如果您以大寫字母作為方法名的開頭,Ruby 可能會把它當作常量,進而導緻不正确地解析調用。

方法應在調用之前定義,否則 Ruby 會産生未定義的方法調用異常。

def method_name [( [arg [= default]]...[, * arg [, &expr ]])]

expr..

end

是以,您可以定義一個簡單的方法,如下所示:

def method_name

您可以定義一個接受參數的方法,如下所示:

def method_name (var1, var2)

您可以為參數設定預設值,如果方法調用時未傳遞必需的參數則使用預設值:

def method_name (var1=value1, var2=value2)

當您要調用方法時,隻需要使用方法名即可,如下所示:

method_name

但是,當您調用帶參數的方法時,您在寫方法名時還要帶上參數,例如:

method_name 25, 30

使用帶參數方法最大的缺點是調用方法時需要記住參數個數。例如,如果您向一個接受三個參數的方法隻傳遞了兩個參數,Ruby 會顯示錯誤。

#!/usr/bin/ruby

# -*- coding: UTF-8 -*-

def test(a1="Ruby", a2="Perl")

puts "程式設計語言為 #{a1}"

puts "程式設計語言為 #{a2}"

test "C", "C++"

test

以上執行個體運作輸出結果為:

Ruby 中的每個方法預設都會傳回一個值。這個傳回的值是最後一個語句的值。例如:

def test

i = 100

j = 10

k = 0

在調用這個方法時,将傳回最後一個聲明的變量 k。

Ruby 中的 return 語句用于從 Ruby 方法中傳回一個或多個值。

return [expr[`,' expr...]]

如果給出超過兩個的表達式,包含這些值的數組将是傳回值。如果未給出表達式,nil 将是傳回值。

return

return 12

return 1,2,3

看看下面的執行個體:

j = 200

k = 300

return i, j, k

var = test

puts var

假設您聲明了一個帶有兩個參數的方法,當您調用該方法時,您同時還需要傳遞兩個參數。

但是,Ruby 允許您聲明參數數量可變的方法。讓我們看看下面的執行個體:

def sample (*test)

puts "參數個數為 #{test.length}"

for i in 0...test.length

puts "參數值為 #{test[i]}"

sample "Zara", "6", "F"

sample "Mac", "36", "M", "MCA"

在這段代碼中,您已經聲明了一個方法 sample,接受一個參數 test。但是,這個參數是一個變量參數。這意味着參數可以帶有不同數量的變量。以上執行個體運作輸出結果為:

當方法定義在類的外部,方法預設标記為 private。另一方面,如果方法定義在類中的,則預設标記為 public。

方法預設的可見性和 private 标記可通過子產品(Module)的 public 或 private 改變。

當你想要通路類的方法時,您首先需要執行個體化類。然後,使用對象,您可以通路類的任何成員。

Ruby 提供了一種不用執行個體化即可通路方法的方式。讓我們看看如何聲明并通路類方法:

class Accounts

def reading_charge

def Accounts.return_date

我們已經知道方法 return_date 是如何聲明的。它是通過在類名後跟着一個點号,點号後跟着方法名來聲明的。您可以直接通路類方法,如下所示:

Accounts.return_date

如需通路該方法,您不需要建立類 Accounts 的對象。

這個語句用于為方法或全局變量起别名。别名不能在方法主體内定義。即使方法被重寫,方法的别名也保持方法的目前定義。

為編号的全局變量($1, $2,...)起别名是被禁止的。重寫内置的全局變量可能會導緻嚴重的問題。

alias 方法名 方法名

alias 全局變量 全局變量

alias foo bar

alias $MATCH $&

在這裡,我們已經為 bar 定義了别名為 foo,為 $& 定義了别名為 $MATCH。

這個語句用于取消方法定義。undef 不能出現在方法主體内。

通過使用 undef 和 alias,類的接口可以從父類獨立修改,但請注意,在自身内部方法調用時,它可能會破壞程式。

undef 方法名

下面的執行個體取消名為 bar的方法定義:

undef bar