我是因为用了coffee所以萌生出想学学ruby的想法的,因为才刚开始学习,所以有些问题可能比较初级。
我看的代码里大量使用了:xxxx
之类的语法,我从网上查到这个叫Symbol
,从用法上来看它的本质应该是不是一种不需要预定义,但是会被预编译的常量?
作为从其他语言转向ruby的,我发现ruby在一个class调用this
有如下几种
self.xxxx
xxxx
方法@
这给我这种习惯了在java
, php
这类语言里只有一种方法引用类本身的人带来了疑惑(当然java也可以省略this),可以具体解释下这三类用法的区别么?
我在很多rails项目发现了这种代码
class Person
attr_accessor :name
def set_name(your_name)
name = your_name
end
end
def ... end
那个没啥问题,但是前面的attr_accessor :name
怎么看怎么像一个正常的方法调用嘛,是这样吗?这里的方法跟一般的方法有啥不同?为啥要这样写。因为一般的语言class里都只是声明语法,虽然scala
之类的语言也可以执行代码,但不知道ruby的这种写法有什么应用场景。
天蓬老师2017-04-22 09:01:56
attr_accessor
生成getter和setter方法。同样的,attr_reader
生成getter,而attr_writer
生成setter。在ruby里,在class中执行特殊的方法是常见的做法,这些方法一般都是用来修改(或增添)该class的某些特性的。巴扎黑2017-04-22 09:01:56
1.String在ruby中是变量 Symbol是常量
2. 1和2相同 @是类成员 一个方法提供多重途径调用在ruby中很常见
3.等同于提供了默认的getter/setert方法
伊谢尔伦2017-04-22 09:01:56
你的问题有上下文关系,我倒着回复,你可能更好理解:)
执行代码,看看结果。就明白了。attr_accessor 是一个方法,执行完后,会动态添加方法到class内。
这就是ruby的元编程。很牛的说:
module Mod
attr_accessor(:one, :two)
end
Mod.instance_methods.sort #=> [:one, :one=, :two, :two=]
刚刚的attr_accessor 的例子,其中用到了symbol(冒号打头的)。
为何不用字符串?因为用这个方法要生成很多方法,而方法是一种符号,而不是字符串。更加细节的,我以前是从自己写Lisp 解释器的时候,了解了symbol vs. string的区别。而ruby因为支持元编程,因此引入了一些编译器的概念进来,增强了语言的柔性。这个是确实很牛的。
就是说,需要区分类方法和实例方法。class method vs. member method .这个其他的语言,很多也支持这样的差别。
简而言之,class method 不必实例化就可以调用,而member method必须实例才能调用。
class foo def bar end end
foo.new.bar #调用实例方法,必须先new
class foo def self.bar end end
foo.bar #无需实例化
ref:http://www.railstips.org/blog/archives/2009/05/11/class-and-instance-methods-in-ruby/
高洛峰2017-04-22 09:01:56
ruby的方法都是通过对象调用的,该对象称为方法的receiver,对象的方法是在该对象所属的类中定义的。
如何确定方法的receiver呢?可以遵循以下原则。
1.显式调用时,receiver很显然,就是你给出的那个对象。
2.隐式调用的方法,其receiver为self。
3.self是指:
(1)在模块/类内部,self指的是该模块/类(ruby的模块/类也是对象)。如
class MyClass
self #这里self就是MyClass对象
end
(2)在方法内部,self指的是该方法的receiver。如
def method
self #这里self就是调用该方法时使用的receiver
#它是在方法被调用时才确定下来的
end
@开头的是实例变量,跟方法是两码事。
ruby的学问太多,三言两语很难说清楚,这里提到的只是冰山一角。ruby有一套非常严谨完备的逻辑体系。