本文简要介绍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 Location.lineno用法及代码示例
- Ruby Location.label用法及代码示例
- Ruby Location.path用法及代码示例
- Ruby LocalJumpError类用法及代码示例
- Ruby LoadError类用法及代码示例
- Ruby Logger类用法及代码示例
- Ruby Logger.info用法及代码示例
- Ruby Lazy.collect用法及代码示例
- Ruby Lazy.collect_concat用法及代码示例
- Ruby Lazy.flat_map用法及代码示例
- Ruby List.append用法及代码示例
- Ruby Lazy._enumerable_map用法及代码示例
- Ruby Lazy.enum_for用法及代码示例
- Ruby List.prepend用法及代码示例
- Ruby LDAP.build用法及代码示例
- Ruby Lazy._enumerable_flat_map用法及代码示例
- Ruby Lazy.new用法及代码示例
- Ruby Lazy._enumerable_filter_map用法及代码示例
- Ruby Lazy._enumerable_collect用法及代码示例
- Ruby Lazy.filter_map用法及代码示例
- Ruby Lazy.to_enum用法及代码示例
- Ruby Lazy._enumerable_collect_concat用法及代码示例
- Ruby Lazy.map用法及代码示例
- Ruby LDAP.new用法及代码示例
- Ruby Lazy类用法及代码示例
注:本文由纯净天空筛选整理自ruby-lang.org大神的英文原创作品 Location类。非经特殊声明,原始代码版权归原作者所有,本译文未经允许或授权,请勿转载或复制。