当前位置: 首页>>代码示例 >>用法及示例精选 >>正文


Ruby Location类用法及代码示例


本文简要介绍ruby语言中 Thread::Backtrace::Location类 的用法。

堆栈帧的对象表示,由 Kernel#caller_locations 初始化。

例如:

# caller_locations.rb
def a(skip)
  caller_locations(skip)
end
def b(skip)
  a(skip)
end
def c(skip)
  b(skip)
end

c(0..2).map do |call|
  puts call.to_s
end

运行 ruby caller_locations.rb 将产生:

caller_locations.rb:2:in `a'
caller_locations.rb:5:in `b'
caller_locations.rb:8:in `c'

这是另一个结果略有不同的示例:

# foo.rb
class Foo
  attr_accessor :locations
  def initialize(skip)
    @locations = caller_locations(skip)
  end
end

Foo.new(0..2).locations.map do |call|
  puts call.to_s
end

现在运行ruby foo.rb,你应该看到:

init.rb:4:in `initialize'
init.rb:8:in `new'
init.rb:8:in `<main>'

相关用法


注:本文由纯净天空筛选整理自ruby-lang.org大神的英文原创作品 Location类。非经特殊声明,原始代码版权归原作者所有,本译文未经允许或授权,请勿转载或复制。