方法只针对一个实例?他们在Ruby中称之为什么?
我知道有“实例方法”,“类方法”,但这些类型的方法被称为,例如:
s1 = "This is my STRING!" def s1.m1 downcase end p s1 # => "This is my STRING!" p s1.m1 # => "this is my string!" 什么类型的方法是在“字符串”类的s1“实例”上调用的“m1”方法?这真的很奇怪,因为如果我尝试的话,我根本不知道这是可能的: s2 = "This is ANOTHER string" s2.m1 # => Won't work! 哪种有意义,但不确定为什么在类的实例上定义像m1这样的方法是有用的. 解决方法
它们被称为单例方法,可以定义如下:
class Person def favorite_meal "Big Mac" end end Fred,Joe = 2.times.map { Person.new } def Fred.favorite_meal "Le Big Mac" end Joe.favorite_meal #=> Big Mac Fred.favorite_meal #=> Le Big Mac 定义相同单例方法的其他方法是: Fred.define_singleton_method :favorite_meal do "Le Big Mac" end 和: class << Fred def favorite_meal "Le Big Mac" end end 愿原力与你同在. 更新:回答评论中的2个问题. 让我从第二个开始.无论您使用常量还是变量,都取决于您.写fred = Person.new是完全可以的.但: >具有不同属性的对象通常应该具有正确的名称,这些名称是正确的. 通过gem install y_support安装它,并尝试: require 'y_support/name_magic' class Dog include NameMagic def speak; puts "Bow wow!" end end Spot,Rover = 2.times.map { Dog.new } 现在Dog类知道它的实例,实例知道它们的名字. Dog.instances.map { |dog| dog.name } #=> :Spot,:Rover Dog.instances.names # the simpler way to say the same 这在这个特定的例子中没有用(并且在其他地方非常有用),但无论如何,它给了我一个习惯,即给予具有个性特征的对象. 至于第一个问题,def Fred.foobar是最基本的,一次性的单例方法定义.如果要在单例类中定义多个单例方法或别名或包含模块,请使用class<<弗雷德: module Foo def bar; "Fretbar!" end end class << Fred include Foo alias le_favorite favorite_meal end Fred.bar #=> Fretbar! Fred.le_favorite #=> "Le Big Mac" 使用Fred.define_singleton_method语法可以实现最高级的功能,并且使用第4种方法,我之前没有提到过: local_var = 42 Fred.singleton_class.class_exec do define_method :baz do local_var + 1 end end Fred.baz #=> 43 这种方式使用闭包,它保留与变量local_var的绑定.试试看 local_var = 32 Fred.baz #=> 33 所以这是关于闭包语法的特殊之处,它通常是一个天赐之物,可以神奇地解决令人讨厌的编程问题. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |