Jai*_*Jai 7 ruby open-source ruby-on-rails
我是Ruby on Rails框架的用户,我想通过贡献代码来回馈它.我理解有必要彻底了解Ruby语言概念吗?我克隆了项目,查看了代码,检查了门票,并且不知道如何开始?从我看到Rails框架利用元编程很多?那么,为了开始贡献,我必须掌握Ruby的其他方面吗?或者贡献是了解Ruby的来龙去脉?谢谢.!
自从我遇到我不理解的 ruby 代码以来已经有一段时间了,但是 Rails 的某些部分确实促进了我对 ruby 的理解。
话虽这么说,即使您的语言水平处于中级水平,了解 Rails 的工作原理也可能是提高您水平的好方法。
至于从哪里开始,我会从编写插件开始。想一个你可以编写但尚未完成的很酷的插件,或者你认为你可以做得更好的东西。无论您想做什么,您很可能需要连接某种 Rails 内部组件来完成它,这将为您提供一个良好的起点。一旦您对框架的给定区域有了一定的了解,请查看该区域中是否存在可以修复的任何未解决的错误。
门槛相当高,因为 Rails 是一个相当大且复杂的程序,由对一种极其灵活的语言具有高度掌握水平的人编写。这也是一个巨大的挑战,最终可能会让你成为一个更好的程序员。:)
编辑:帮助栏杆
如果它是一个旨在说明类变量和单例类如何工作的片段,那么这实际上非常有趣,但如果它是“真实”代码,则有更清晰的方法来完成相同的事情。
在 ruby 中,每个对象都有一个从中获取方法的父类。这对于 OO 语言来说很正常。不正常的是 ruby 还有一个称为“对象个性化”的概念,这意味着对象可以拥有仅在特定实例上的方法,但不能在父类上。这是一个快速的 irb 示例
irb(main):001:0> foo = "bar"
=> "bar"
irb(main):002:0> def foo.foo_method
irb(main):003:1> "this is _only_ on the foo instance, not on all strings"
irb(main):004:1> end
=> nil
irb(main):005:0> foo.foo_method
=> "this is _only_ on the foo instance, not on all strings"
irb(main):006:0> "bar".foo_method
NoMethodError: undefined method `foo_method' for "bar":String
from (irb):6
irb(main):007:0> foo = "New string"
=> "New string"
irb(main):008:0> foo.foo_method
NoMethodError: undefined method `foo_method' for "New string":String
from (irb):8
Run Code Online (Sandbox Code Playgroud)
首先,我们将一个字符串分配给一个变量。接下来,我们在该实例上定义一个方法。调用该方法有效,但在新字符串上调用它不起作用。将新的字符串实例分配给我们的 foo 变量也没有该 foo 方法。
为了使对象个性化成为可能,实例和父类之间需要有一些东西。这个东西就是单例类,每个实例都有一个与所有其他对象实例不同的唯一类。当 ruby 查找方法时,它会先查找单例类,然后再查找父类。
不管您是否相信,即使您以前从未听说过它,您也可能已经使用过它。如果你想向某些东西添加“类方法”,你通常会这样做
class Foo
def self.bar
"i am on the class"
end
end
Foo.bar #=> "I am on the class"
Run Code Online (Sandbox Code Playgroud)
从顶部开始,该语句class Foo与此完全相同Foo = Class.new do。发生的情况是您将 Class 类型的新实例分配给常量 Foo。(顺便说一句,这就是我喜欢 ruby 的原因。大多数语法实际上只是围绕一些核心概念的糖衣)
在类定义中, self 指的是类,所以说def self.bar本质上是在说“在存储在常量 Foo 中的 Class 实例的单例类上定义方法 bar”。
如果你觉得这个东西很复杂,那是因为它确实很复杂。我认为除了方法查找过程中发生的事情之外,Ruby 中没有其他更复杂的事情了,而单例类是使其如此复杂的重要原因。
类变量以@@, 为前缀,基本上是一个范围为所有实例、类对象以及从该类继承的所有类的变量。我将做一个快速的 irb 来说明这一点
irb(main):003:0* class Foo
irb(main):004:1> @@instance_count = 0
irb(main):005:1>
irb(main):006:1* def initialize
irb(main):007:2> @@instance_count += 1
irb(main):008:2> end
irb(main):009:1>
irb(main):010:1* def count
irb(main):011:2> @@instance_count
irb(main):012:2> end
irb(main):013:1> end
=> nil
irb(main):014:0>
irb(main):015:0* class Bar < Foo
irb(main):016:1> end
=> nil
irb(main):017:0>
irb(main):018:0* f = Foo.new
=> #<Foo:0x7fa9089c7da0>
irb(main):019:0> f.count
=> 1
irb(main):020:0>
irb(main):021:0* b = Bar.new
=> #<Bar:0x7fa9089be0e8>
irb(main):022:0> b.count
=> 2
irb(main):023:0>
irb(main):024:0* f.count
=> 2
Run Code Online (Sandbox Code Playgroud)
首先,我们定义 Foo。Foo 有一个类变量来跟踪创建了多少个实例。为此,我们在构造函数中增加该变量,最后定义一个快速获取器。Bar 只是扩展了 Foo。
现在,为了查看它的实际效果,我们创建一个新的 foo,并检查计数,为 1。接下来,我们创建一个新的 bar,并检查计数,我们现在为 2。只是为了确保 Foo 和Bar 共享相同的计数,我们再次检查 foo 实例,现在它是 2。
类变量是一种非常情境化的功能,您通常在框架代码之外看不到。当您想要跟踪给定类的所有实例时,通常会使用它。
class << Object.new
@@var = 6
end
String.class_variable_get(:@@var) #=> 6
Run Code Online (Sandbox Code Playgroud)
您的代码正在实际显示这两个概念。首先,我们打开一个新对象的单例类,并在其上放置一个类变量。如果它不是类变量,那么前三行将是世界上最无用的 ruby 代码。但由于它是一个类变量,因此它对该类、该类的所有实例、从该类继承的所有类以及从该类继承的所有类的所有实例都可见。由于我们谈论的类是对象,因此意味着一切。因此,对 String 执行 class_variable_get 即可获得该变量,但您可以从任何您想要的类或实例访问该变量。
这是非常复杂的事情,很难清楚地解释。这些概念花了我大约一周左右的时间才弄清楚。如果您对我写的内容有任何疑问,请随时提出,但如果您没有“明白”,也不要灰心。
| 归档时间: |
|
| 查看次数: |
271 次 |
| 最近记录: |