Ruby中关于模块的一些基础知识

所属分类: 脚本专栏 / ruby专题 阅读数: 2039
收藏 0 赞 0 分享

模块与类很相似,它也可以说成是“不能被实例化的类”。由于Class类是Module类的子类,所以说成是“类=模块+实例化能力”也许更好。

所谓模块,究竟是用来干什么的呢?其作用主要有两大类:Mix-in和命名空间。

Mix-in实际上是受限制的多重继承。利用实际做成的继承关系,可以实现对某些类进行一些“点缀”的目的。事实上,Mix-in这种说法就来自于在冰激凌上面的饼干或者坚果。

在面向对象设计的历史中,由多重继承机制造成的问题早已众所周知了。所以,很多现代的面向对象设计语言都只支持单一继承的方式。Ruby就是采用的这种方式。

但是,多重继承机制也有不能被割舍的魅力。因此Ruby通过采用Mix-in的方式引入了很多多重继承的优点。

一个类如果同时继承了多个类,就会很容易在面向对象设计上出现很多问题。因此,Ruby加入了以下限制:

1、 只能继承一个类

2、 可以继承多个所谓的“像类但不是类”的模块

此外,Ruby把“在类中加入模块”的动作称为include。

模块的另一个功能是提供命名空间

在大规模的程序开发中,命名冲突的问题经常会出现。比如读者在程序中需要制作一个名为Service的类,但是Service这个名字却已经在程序库中被使用了,这就是命名冲突的问题。

在很多现代的编程语言中,为了避免命名冲突的问题,基本上都提供了命名空间或者包的功能。在不同的命名空间中存在的Service类虽然类名相同,但是会被作为不同的对象来处理。

在Ruby中,通常会利用模块来提供这样的命名空间。
 

class Service; end
module Library
  class Service; end
end

 最开始的Service类属于Top Level的命名空间,后面的Service类则属于Library模块。

这其实就是Top Level和Library模块中分别定义了名为Service的常量(类名实际上是指向class对象的常量)。

因此,在使用时就像使用常量一样。
 

::Service       #Top Level的Service
Library::Service  #Library的Service

更多精彩内容其他人还在看

Ruby一行代码实现的快速排序

这篇文章主要介绍了Ruby一行代码实现的快速排序,本文直接给出实现代码,超级简洁的一个的方法,需要的朋友可以参考下
收藏 0 赞 0 分享

Ruby实现的3种快速排序算法

这篇文章主要介绍了Ruby实现的3种快速排序算法,本文给出了快速排序的普通版本、快速排序的随机化版本、快速排序的利用了Ruby的语法糖的随机化版本三个版本,需要的朋友可以参考下
收藏 0 赞 0 分享

Ruby实现的最优二叉查找树算法

这篇文章主要介绍了Ruby实现的最优二叉查找树算法,本文直接给出实现代码,需要的朋友可以参考下
收藏 0 赞 0 分享

Ruby实现的最短编辑距离计算方法

这篇文章主要介绍了Ruby实现的最短编辑距离计算方法,本文直接给出实现代码,需要的朋友可以参考下
收藏 0 赞 0 分享

Ruby实现的最长公共子序列算法

这篇文章主要介绍了Ruby实现的最长公共子序列算法,本文直接给出实现代码,需要的朋友可以参考下
收藏 0 赞 0 分享

Ruby实现的合并排序算法

这篇文章主要介绍了Ruby实现的合并排序算法,本文直接给出实现代码,需要的朋友可以参考下
收藏 0 赞 0 分享

Ruby实现的矩阵连乘算法

这篇文章主要介绍了Ruby实现的矩阵连乘算法,本文直接给出实现代码,需要的朋友可以参考下
收藏 0 赞 0 分享

Ruby实现的各种排序算法

这篇文章主要介绍了Ruby实现的各种排序算法,本文给出了Bubble sort、Insertion sort、Selection sort、Shell sort等排序的实现方法,需要的朋友可以参考下
收藏 0 赞 0 分享

Ruby实现生产者和消费者代码分享

这篇文章主要介绍了Ruby实现生产者和消费者代码分享,本文直接给出实现代码,需要的朋友可以参考下
收藏 0 赞 0 分享

Ruby中require、load、include、extend的区别介绍

这篇文章主要介绍了Ruby中require、load、include、extend的区别介绍,require、load用于文件,如.rb等等结尾的文件,include、load则用于包含一个文件中的模块,需要的朋友可以参考下
收藏 0 赞 0 分享
查看更多