介绍Ruby中的模块与混合类型的相关知识_ruby专题

模块是组合在一起的方法,类和常量。模块两个主要好处:

  •     模块提供了一个命名空间,并避免名称冲突。
  •     模块实现混合工厂。

模块定义了一个命名空间,一个沙箱中方法和常量可以自由使用,而不必担心踩到其他的方法和常数。
语法:

module Identifier
  statement1
  statement2
  ...........
end

就像被命名为类常量模块中的常量,首字母大写。定义的方法看起来很相似,模块定义方法就像类的方法。

调用一个模块方法和类方法一样,通过模块的名称它名字前,引用一个常数使用该模块的名称和两个冒号。
例子:

#!/usr/bin/ruby

# Module defined in trig.rb file

module Trig
  PI = 3.141592654
  def Trig.sin(x)
  # ..
  end
  def Trig.cos(x)
  # ..
  end
end

我们可以定义一个函数名相同,但在不同的功能模块:

#!/usr/bin/ruby

# Module defined in moral.rb file

module Moral
  VERY_BAD = 0
  BAD = 1
  def Moral.sin(badness)
  # ...
  end
end

和类的方法一样,当在一个模块中定义的方法,指定模块名称后面跟着一个点,那么该方法的名称。
Ruby require 语句:

require 语句声明的是类似于 C/C++ 的 include语句 和 Java 的 import 语句。如果有第三个程序要使用任何定义的模块,它可以简单地使用Ruby require 语句加载的模块文件:
语法:

require filename

在这里,它不是必需的  .rb 文件名扩展。
例如:

require 'trig.rb'
require 'moral'

y = Trig.sin(Trig::PI/4)
wrongdoing = Moral.sin(Moral::VERY_BAD)

重要: 在这里,这两个文件都包含相同的函数名。因此,这将导致在代码中的歧义,同时包括在调用程序,但的模块避免这个代码模糊,我们能够调用适当的功能模块的名称。
Ruby include 语句:

可以嵌入在一个类模块。要在一个类中嵌入模块,可以使用类中 include 语句:
语法:

include modulename

如果一个模块被定义在单独的文件,那么它需要包含该文件需要隐藏于公开的模块在一个类的 require  语句之前。
例子:

考虑以下模块写在support.rb文件。

module Week
  FIRST_DAY = "Sunday"
  def Week.weeks_in_month
   puts "You have four weeks in a month"
  end
  def Week.weeks_in_year
   puts "You have 52 weeks in a year"
  end
end

现在,可以在如下一类包括这个模块:

#!/usr/bin/ruby
require "support"

class Decade
include Week
  no_of_yrs=10
  def no_of_months
   puts Week::FIRST_DAY
   number=10*12
   puts number
  end
end
d1=Decade.new
puts Week::FIRST_DAY
Week.weeks_in_month
Week.weeks_in_year
d1.no_of_months

这将产生以下结果:

Sunday
You have four weeks in a month
You have 52 weeks in a year
Sunday
120

Ruby中混合类型:

通过本节之前,假设有面向对象的概念和知识。

当一个类可以从多个父类继承的特点,类应该显示多重继承。

Ruby没有直接中suppoprt多继承,但Ruby的模块有另一个精彩使用。他们几乎消除多重继承的需要,提供了一个工厂称为混入。

混合类型给一个精彩的控制方式增加功能类。在代码中混合类,使用它的代码能进行进行交互。

让我们来看看下面的示例代码来获得混合类型了解:

module A
  def a1
  end
  def a2
  end
end
module B
  def b1
  end
  def b2
  end
end

class Sample
include A
include B
  def s1
  end
end

samp=Sample.new
samp.a1
samp.a2
samp.b1
samp.b2
samp.s1

模块A包括一种方法,a1和a2。模块B包括一种方法,b1和b2。类示例包括两个模块A和B类的样品可以访问所有四种方法,即a1, a2, b1 或 b2。因此,可以看到这个类继承自两个模块样品。因此,可以说类的示例显示了多重继承或混入。

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索ruby
ruby 判断变量类型、ruby 判断类型、ruby 数据类型、ruby类型转换、ruby 模块,以便于您获取更多的相关知识。

时间: 2024-08-07 17:47:45

介绍Ruby中的模块与混合类型的相关知识_ruby专题的相关文章

介绍Ruby中的模块与混合类型的相关知识

  这篇文章主要介绍了Ruby中的模块与混合类型的相关知识,包括平常人们常说的多态与继承等相关知识点,需要的朋友可以参考下 模块是组合在一起的方法,类和常量.模块两个主要好处: 模块提供了一个命名空间,并避免名称冲突. 模块实现混合工厂. 模块定义了一个命名空间,一个沙箱中方法和常量可以自由使用,而不必担心踩到其他的方法和常数. 语法: ? 1 2 3 4 5 module Identifier statement1 statement2 ........... end 就像被命名为类常量模块中

Ruby中的Hash哈希类型基本操作方法小结_ruby专题

1.创建哈希:就像创建数组一样,我们可以通过Hash类来创建一个Hash实例: h1 = Hash.new #默认值为nil h2 = Hash.new("This is my first hash instance") #默认值为" This is my first hash instance": 上面两个例子都创建了一个空的Hash实例.一个Hash对象总是有一个默认的值--因为如果在一个Hash对象里没有找到指定的索引(key),将会返回默认值. 创建了Has

在Ruby中利用Net::SMTP类发送电子邮件的教程_ruby专题

简单邮件传输协议(SMTP)发送电子邮件及路由的e-mail邮件服务器之间的协议处理. Ruby 提供 Net::SMTP 类的简单邮件传输协议(SMTP)客户端的连接,并提供了两个新的方法:new 和 start.     new 带两个参数:         server name 默认为 localhost         port number  默认为熟知的 25     start 方法带有以下这些参数:         server - IP SMTP服务器名称,默认为localh

在Ruby中处理文件的输入和输出的教程_ruby专题

Ruby 提供了一整套 I/O 相关的方法,在内核(Kernel)模块中实现.所有的 I/O 方法派生自 IO 类. 类 IO 提供了所有基础的方法,比如 read. write. gets. puts. readline. getc 和 printf. 本章节将讲解所有 Ruby 中可用的基础的 I/O 函数.如需了解更多的函数,请查看 Ruby 的 IO 类.puts 语句 在前面的章节中,您赋值给变量,然后使用 puts 语句打印输出. puts 语句指示程序显示存储在变量中的值.这将在每

Ruby中Hash哈希结构的基本操作方法小结_ruby专题

关于哈希先来了解一下Hash的基本思路: 设要存储对象的个数为num, 那么我们就用len个内存单元来存储它们(len>=num); 以每个对象ki的关键字为自变量,用一个函数h(ki)来映射出ki的内存地址,也就是ki的下标,将ki对象的元素内容全部存入这个地址中就行了.这个就是Hash的基本思路. 为什么要用一个函数来映射出它们的地址单元呢? 假设现在我要存储4个元素 13 7 14 11 显然,我们可以用数组来存.也就是:a[1] = 13; a[2] = 7; a[3] = 14; a[

ruby中执行周期性任务(定时任务)的3种方法_ruby专题

1.前言      无论是用ruby做系统管理,还是用rails做web开发,都可能遇到周期性任务,它们按照一定时间周期(1小时,2天......)持续地触发.在ruby中,我认为一次性任务使用sidekiq来完成是非常方便的,而周期性的任务就需要用到whenever,sidetiq,clockwork等等gem了. 2.whenever 首先,whenever是基于linux的cron服务的,所以,在windows平台上没有直接的方法使用该gem.whenever严格来说应该算一个cron的翻

Ruby中的public、private、protected区别小结_ruby专题

重点关注private与protected public 默认即为public,全局都可以访问,这个不解释 private C++, "private" 意为 "private to this class", 但是Ruby中意为 "private to this instance". 意思是:C++中,对于类A,只要能访问类A,就能访问A的对象的private方法. Ruby中,却不行:你只能在你本对象的实例中访问本对象的private方法. 因

浅析Ruby中继承和消息的相关知识_ruby专题

继承允许你创建一个类,作为另一个类的精炼(refinement)和特化(specialization).例如,在我们的自动点唱机系统中,有"歌曲"这一概念,被封装在Song类中,然后,随着市场的成长,我们需要提供卡拉OK的支持.一首卡拉OK歌曲和其他歌曲没什么两样(它只是没有主唱的音轨,对此我们不必关心).不过,它还包括对于的一套歌词以及时间信息.当我们的自动点唱机在播放一首卡拉OK歌曲时,歌词应该随音乐滚动显示在点唱机前的屏幕上. 解决这个问题的一种方法是定义一个新的类Karaoke

Ruby中使用Block、Proc、lambda实现闭包_ruby专题

闭包(Closure),是指未绑定到任何对象的自由代码,闭包中的代码与任何对象和全局变量无关,只与执行此段代码的上下文相关. 今天我们简要的看一下ruby中的闭包实现. Ruby中的闭包实现有:Block,Proc,Lambada. 首先,我们来看Block. 复制代码 代码如下: ary = [1,2,3,4] ary.collect! do |a|         a*a end ary.each do |a|         puts a end 这段代码,我们使用了Array对象的blo