例如,我想看看 @time 宏的“内部”是什么。我该怎么做?
macroexpand
查看宏扩展的结果。例如:
julia> macroexpand(:(@time rand(10)))
:(begin # util.jl, line 38:
local #60#b0 = Base.gc_bytes() # line 39:
local #61#t0 = Base.time_ns() # line 40:
local #62#val = rand(10) # line 41:
local #63#t1 = Base.time_ns() # line 42:
local #64#b1 = Base.gc_bytes() # line 43:
Base.println("elapsed time: ",Base./(Base.-(#63#t1,#61#t0),1.0e9)," seconds (",Base.-(#64#b1,#60#b0)," bytes allocated)") # line 44:
#62#val
end)
在这种情况下,它还会显示它的定义位置(util.jl,第 38 行),但这并不总是发生。
我认为没有内置的方法可以做到这一点,但您可以在代码库中搜索“macro X”。
这听起来像是一个有用的功能,所以除非有人纠正我并且它已经存在,否则你可以随时提出一个请求它的问题。
至少从 0.5 开始,你也可以
@less
宏:
julia> @less @time x
将打开一个编辑器,其中显示代码
macro time(ex)
quote
local stats = gc_num()
local elapsedtime = time_ns()
local val = $(esc(ex))
elapsedtime = time_ns() - elapsedtime
local diff = GC_Diff(gc_num(), stats)
time_print(elapsedtime, diff.allocd, diff.total_time,
gc_alloc_count(diff))
val
end
end