如果Ruby和Python都允许进行猴子补丁,那为什么Ruby更有争议?

在许多讨论中,我已经听说过 Ruby,人们对这个语言表达了自己的看法,猴子补丁的问题成了他们的主要关切之一.

然而,我很少听到在Python的上下文中提到的相同论据,尽管Python语言也是允许的.

为什么这个区别?

Python是否包含不同类型的保护措施,以最大限度地减少此功能的风险?

解决方法

作为一个熟悉Ruby(并喜欢它)的Python程序员,我认为当Python开始流行时,有一点讽刺意味.

C和Java程序员会“抨击”Python,指出它不是一种真正的语言,而且它的类型的动态性将是危险的,并允许人们创建“坏”代码.随着Python变得越来越流行,其快速开发时间的优势变得明显,更不用说冗长的语法:

// Java
Person p = new Person();
# Python
p = Person()

我们开始看到更多的动态特性出现在Java的更高版本中. AutoBoxing和-unBoxing使处理原语变得不那么麻烦,而泛型允许我们编码一次并将其应用于许多类型.

有一些娱乐,我看到了Ruby – Monkey Patching的一个关键的灵活功能,被Python人群所吹捧.今年开始向学生教授Ruby,我认为能够“修复”现有课堂的实现,即使是系统的一部分也是非常强大的.

当然,你可以拧坏你的程序可能会崩溃.我也可以很容易地在C中进行segfault.而Java应用程序可能会导致火焰死亡.

事实是,我认为Monkey Patching是动态和元编程的下一步.有趣的是,自从Smalltalk以来已经有了.

相关文章

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