当前位置 : 主页 > 编程语言 > ruby >

在Ruby中,`Float(…)`记录在哪里?

来源:互联网 收集:自由互联 发布时间:2021-06-23
在 Ruby语言中,您可以像函数一样调用Float,以确保参数是Float或可解析为float的字符串(包括科学记数法等). 例如: Float(1.0) # = 1.0Float('1.0') # = 1.0Float('-1.23') # = -1.23Float('-1e+2') # = -100.0 但是
在 Ruby语言中,您可以像函数一样调用Float,以确保参数是Float或可解析为float的字符串(包括科学记数法等).

例如:

Float(1.0)     # => 1.0
Float('1.0')   # => 1.0
Float('-1.23') # => -1.23
Float('-1e+2') # => -100.0

但是,Ruby文档似乎并没有在任何地方描述这种行为(Float v2.1.0,Float v1.9.3).

我在哪里可以找到此功能的文档?

它在这里被定义为 Kernel#Float.这个函数是ruby提供的内置转换函数(由Avdi Grimm创造的术语)的一部分.

“你真的,真的,想要将输入对象转换为核心类型,无论原始类型是什么.例如,如果有任何合理的方法,你需要确保任何输入被强制转换为整数 – 传入数据是Float,nil还是十六进制字符串.
“自信的代码,Avdi Grimm.

例如,使用Kernel#Array转换函数,想象一个占用0个,1个或更多帖子的方法.

def process_post(post_or_posts)
    posts = Array(post_or_posts)
    posts.each do |post|
      .... # do something post
    end
  end

当使用不同的输入调用方法时,这提供了一些灵活性:

process_post("post1")
 process_post(["post1", "post2"])
 process_post(nil)

如果我们在没有函数的情况下实现它,我们可能需要做这样的事情:

def process_post(post_or_post)
   if post_or_post    # now we have to check for nil
      # we might have to check for instance of Array to make sure we can iterate now.
      # etc..
   end
 end

这一系列功能无疑可以创建灵活的API.

网友评论