手机
当前位置:查字典教程网 >脚本专栏 >ruby专题 >Ruby中的p和puts的使用区别浅析
Ruby中的p和puts的使用区别浅析
摘要:p和puts是Ruby中特别常用的方法,很多童鞋可能认为它们是差不多的,使用的时候也不加注意,但是仔细考究起来,它们是有明显差别的。先举一个...

p 和 puts 是 Ruby 中特别常用的方法,很多童鞋可能认为它们是差不多的,使用的时候也不加注意,但是仔细考究起来,它们是有明显差别的。

先举一个例子

复制代码 代码如下:

class Foo

def inspect

"foo from inspect"

end

def to_s

"foo from to_s"

end

end

foo = Foo.new

p foo

puts foo

p "p: <#{foo}>"

puts "p: <#{foo}>"

这段代码的输出是

复制代码 代码如下:

foo from inspect

foo from to_s

p: <foo from to_s>

puts: <foo from to_s>

p obj 相当于 puts obj.inspect,而 puts obj 相当于 puts obj.to_s, 使用的方便是明显区别的,p 是使用 obj 的 inspect 方法,而 puts 是 to_s 方法。

为什么会这样呢?这个我想可以从 to_s 和 inspect 的区别说起,to_s 是对象的字符串表示, 是 puts 和双引号字符使用的方法。inspect 是对象状态的表示,通用用于 debug 中。 Object 中的定义了 to_s 和 inspect 方法,默认都是返回对象的类名和地址。

所以p 和 puts主要是用途的不同,p 是作为 debug 输出,而 puts 作为对象的字符串表示输出。

另外值得一提的是,在 irb console 中,命令行中表达式求值,使用的是 p 对象的 inspect 方法。另外,通常 debug 输出命令,也是使用对象的 inspect 方法。

【Ruby中的p和puts的使用区别浅析】相关文章:

在Ruby程序中连接数据库的详细教程

Ruby中相等性判断的4种方法

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

Ruby中使用SWIG编写ruby扩展模块实例

在Ruby中创建和使用哈希的教程

Rails Routes中new、collection、member的区别浅析

Ruby中XML格式数据处理库REXML的使用方法指南

Ruby语言中的String深入理解

ruby 迭代器使用方法

Ruby中的Mechanize的使用教程

精品推荐
分类导航