在Ruby中p和puts有区别吗?
当前回答
这可能说明了一个关键的区别,即p返回传递给它的值,而as puts返回nil。
def foo_puts
arr = ['foo', 'bar']
puts arr
end
def foo_p
arr = ['foo', 'bar']
p arr
end
a = foo_puts
=>nil
a
=>nil
b = foo_p
=>['foo', 'bar']
b
['foo', 'bar']
基准数据显示看跌期权速度较慢
require 'benchmark'
str = [*'a'..'z']
str = str*100
res = Benchmark.bm do |x|
x.report(:a) { 10.times {p str} }
x.report(:b) { 10.times {puts str} }
end
puts "#{"\n"*10}"
puts res
0.010000 0.000000 0.010000 ( 0.047310)
0.140000 0.090000 0.230000 ( 0.318393)
其他回答
pfoo输出foo。Inspect后面跟着换行符,即输出Inspect的值而不是to_s,这更适合调试(因为你可以区分1、"1"和"2\b1"之间的区别,如果没有Inspect就不能打印)。
同样重要的是要注意,put“react”到一个定义了to_s的类,而p没有。例如:
class T
def initialize(i)
@i = i
end
def to_s
@i.to_s
end
end
t = T.new 42
puts t => 42
p t => #<T:0xb7ecc8b0 @i=42>
这直接来自.inspect调用,但在实践中并不明显。
除了上面的答案,在控制台输出中有一个微妙的差异——即存在/不存在倒逗号/引号——这可能是有用的:
p "+++++"
>> "+++++"
puts "====="
>> =====
我发现如果你想做一个简单的进度条,使用它们的近亲,打印,这个很有用:
array = [lots of objects to be processed]
array.size
>> 20
这给出了100%进度条:
puts "*" * array.size
>> ********************
这将在每次迭代中增加一个增量*:
array.each do |obj|
print "*"
obj.some_long_executing_process
end
# This increments nicely to give the dev some indication of progress / time until completion
>> ******
foo和foo。inspect是一样的
这两个相等:
p "Hello World"
puts "Hello World".inspect
(inspect提供了一个比to_s方法更直观的对象视图)
推荐文章
- 我如何在Ruby中解析YAML文件?
- Rails中的OO设计:在哪里放置东西
- 给定一个类,查看实例是否有方法(Ruby)
- 在日历应用程序中建模重复事件的最佳方法是什么?
- 如何创建一个私有类方法?
- 无法安装pg gem
- 双* (splat)操作符做什么
- 如何使用Ruby on Rails进行HTTP请求?
- 如何从rake任务中提前返回?
- 什么&。(&点)在Ruby中是什么意思?
- 是什么阻碍了Ruby和Python获得V8的Javascript速度?
- 运行pod设置给我“坏的解释器:没有这样的文件或目录”错误
- 在Ubuntu上安装sqlite3-ruby错误
- Ruby有什么Python没有的,反之亦然?
- find_spec_for_exe':无法找到gem bundle (>= 0.a) (gem::GemNotFoundException)