问题描述
我是朱莉娅的新人。我阅读了关于 julia 静态分析的文档。它给出了一个函数。
function foo(x,y)
z = x + y
return 2 * z
end
并使用 julia 内省函数 code_typed 获取输出:
code_typed(foo,(Int64,Int64))
1-element Array{Any,1}:
:($(Expr(:lambda,{:x,:y},{{:z},{{:x,Int64,0},{:y,{:z,18}},{}},:(begin # none,line 2:
z = (top(Box))(Int64,(top(add_int))(x::Int64,y::Int64))::Int64 # line 3:
return (top(Box))(Int64,(top(mul_int))(2,z::Int64))::Int64
end::Int64))))
它有一个 Expr 。但是当我调用 code_typed 时,输出是:
code_typed(foo,Int64))
1-element Vector{Any}:
CodeInfo(
1 ─ %1 = Base.add_int(x,y)::Int64
│ %2 = Base.mul_int(2,%1)::Int64
└── return %2
) => Int64
朱莉娅有什么变化吗?以及如何根据我的函数和参数类型获取 Exprs?
解决方法
该代码片段似乎取自于 2016 年发布(大约在 Julia 1.0 发布前两年)并引用了 2015 年的 Julia 0.3 版的 https://www.aosabook.org/en/500L/static-analysis.html。
Julia 1.0 提供
julia> code_typed(foo,(Int64,Int64))
1-element Array{Any,1}:
CodeInfo(
2 1 ─ %1 = (Base.add_int)(x,y)::Int64 │╻ +
3 │ %2 = (Base.mul_int)(2,%1)::Int64 │╻ *
└── return %2 │
) => Int64
同时提供更多当前版本,例如 1.6 和 1.7
julia> code_typed(foo,Int64))
1-element Vector{Any}:
CodeInfo(
1 ─ %1 = Base.add_int(x,y)::Int64
│ %2 = Base.mul_int(2,%1)::Int64
└── return %2
) => Int64
(一个更小的变化,但仍然如此)
如果出于任何原因,您希望以数组或 Expr
向量的形式获得此结果,您似乎可以使用(例如)获得此结果
julia> t = code_typed(foo,Int64));
julia> t[1].first.code
3-element Vector{Any}:
:(Base.add_int(_2,_3))
:(Base.mul_int(2,%1))
:(return %2)
虽然这可能被认为是一个实现细节,并且可能会在 Julia 的次要版本之间发生变化。