ruby – “内核”的目的是什么?

>内核模块的目的是什么?如果在内核上定义的所有内容都是在Object上定义的,并且没有像Kernel这样的模块,会发生什么变化?
>当我想定义一个可以在任何对象上调用的方法时,我应该在内核还是在对象上定义它?

解决方法

我将从一个问题开始:在一个典型的 Kernel方法中,例如puts会有什么样的自我?最有意义的自我内部放置可能是Ruby运行时本身.类似于其他“真正想要成为函数的方法”,如 Arrayfork.因此,您可以将内核视为对Ruby本身或多或少的命令或消息的方法的转储基础.

内核也有奇怪的方法,如subchop,它们只适用于一次性ruby -e脚本.这些东西倾向于使用$_作为隐含的自我,但我认为它们可以被视为上面“Ruby运行时命令”的特殊情况.

当您希望能够在任何对象上调用该方法时,方法在哪里?我会说它会进入Object.如果该方法实际上是伪装的函数并且没有有意义的自我,那么它将进入内核.

相关文章

validates:conclusion,:presence=>true,:inclusion=>{...
一、redis集群搭建redis3.0以前,提供了Sentinel工具来监控各...
分享一下我老师大神的人工智能教程。零基础!通俗易懂!风趣...
上一篇博文 ruby传参之引用类型 里边定义了一个方法名 mo...
一编程与编程语言 什么是编程语言? 能够被计算机所识别的表...
Ruby类和对象Ruby是一种完美的面向对象编程语言。面向对象编...