gpt4 book ai didi

ruby-on-rails - 我需要知道什么才能为 Rails 做贡献?

转载 作者:数据小太阳 更新时间:2023-10-29 06:59:16 26 4
gpt4 key购买 nike

关闭。这个问题需要更多focused .它目前不接受答案。












想改善这个问题吗?更新问题,使其仅关注一个问题 editing this post .

6年前关闭。




Improve this question




我是 Ruby on Rails 框架的用户,我正在考虑通过对代码做出贡献来回馈它。
我理解有必要对 Ruby 语言概念的透彻理解做出贡献吗?
我已经克隆了项目,查看了代码,查看了票证,但不知道如何开始?
从我看来,Rails 框架大量使用元编程?那么我必须掌握 Ruby 的哪些其他方面才能开始贡献?或者贡献是了解Ruby的来龙去脉?
谢谢。!

最佳答案

自从我遇到我不理解的 ruby​​ 代码以来已经有一段时间了,但是 Rails 的某些部分确实插入了我对 ruby​​ 的理解。

话虽如此,即使您的语言处于中级水平,弄清楚 rails 的工作原理也可能是提升您的游戏水平的好方法。

至于从哪里开始,我会从编写插件开始。想一个你可以编写但尚未完成的很酷的插件,或者你认为可以做得更好的插件。无论您想做什么,您都可能需要连接到某种 Rails 内部来完成它,这将为您提供一个很好的起点。一旦您对框架的给定区域有了一些了解,请查看该区域是否有任何可以修复的 Unresolved 错误。

障碍相当高,因为 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

首先,我们将一个字符串分配给一个变量。接下来,我们在该实例上定义一个方法。调用该方法有效,但在新字符串上调用它不起作用。为我们的 foo 变量分配一个新的字符串实例也没有那个 foo 方法。

为了使对象个性化成为可能,实例和父类之间需要有一些东西。那就是单例类,每个实例都有一个与所有其他对象实例不同的实例。当 ruby​​ 查找方法时,它会在父类之前查找单例类。

信不信由你,即使你以前从未听说过,你可能已经使用过它。如果你想给某个东西添加一个“类方法”,你通常会这样做
class Foo
def self.bar
"i am on the class"
end
end

Foo.bar #=> "I am on the class"

从顶部开始,声明 class Foo与此完全相同 Foo = Class.new do .发生的事情是您将一个 Class 类型的新实例分配给常量 Foo。 (顺便说一句,这就是我喜欢 ruby​​ 的地方。大部分语法实际上只是围绕一些核心概念的糖)

在类定义中,self 指的是类,所以说 def self.bar本质上是说“在存储在常量 Foo 中的 Class 实例的单例类上定义方法栏”。

如果你觉得这个东西很复杂,那是因为它很复杂。我认为 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

首先,我们定义 Foo。 Foo 有一个类变量,用于跟踪创建了多少个实例。为此,我们在构造函数中增加该变量,最后只定义一个快速 getter 。 Bar 只是扩展 Foo。

现在,为了查看它的实际效果,我们创建一个新的 foo,并检查计数,即 1。接下来,我们创建一个新柱,并检查计数,我们现在是 2。只是为了确保 Foo 和Bar 共享相同的计数,我们再次检查我们的 foo 实例,现在是 2。

类变量是一个非常特殊的特性,您通常在框架代码之外看不到它。当您想要跟踪给定类的所有实例时,通常会使用它。

栏杆代码
class << Object.new 
@@var = 6
end


String.class_variable_get(:@@var) #=> 6

您的代码正在实际展示这两个概念。首先,我们打开一个新对象的单例类,并在其上放置一个类变量。如果它不是类变量,那么前三行将是世界上最无用的 ruby​​ 代码。但由于它是一个类变量,它对类、类的所有实例、从类继承的所有类以及从类继承的所有类的所有实例都是可见的。由于我们正在谈论的类是对象,这意味着一切。因此,在 String 上执行 class_variable_get 会为您提供它,但是您可以从您想要的任何类或实例访问该变量。

对不起

这是非常复杂的东西,很难解释清楚。这些概念花了我大约一周左右的时间,相当一致地努力把我的头脑包围起来。如果您对我所写的内容有任何疑问,请随时提问,但如果您没有“明白”也不要气馁。

关于ruby-on-rails - 我需要知道什么才能为 Rails 做贡献?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3791467/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com