我正在使用Julia v0.6.4。考虑以下模块,该模块保存在FooModule.jl
中:
module FooModule
export Foo
export doSomething
mutable struct Foo
x::Int64
function Foo(xin::Int64)
new(xin)
end # Foo
end # struct
function doSomething(F::Foo)
println(F.x+123)
end # doSomething
end # module
还有一个main.jl
:
using FooModule
function main()
F = Foo(10)
doSomething(F)
end # main
现在我启动Julia REPL:
julia> include("main.jl");
julia> main()
133
即我得到了我的期望。
现在想象doSomething
包含很多行,我想分割FooModule.jl
。我想做这样的事情:
module FooModule
export Foo
export doSomething
include("doSomething.jl") # <- include instead of writing out
mutable struct Foo
x::Int64
function Foo(xin::Int64)
new(xin)
end # Foo
end # struct
end # module
和doSomething.jl
function doSomething(F::Foo)
println(F.x+123)
end # doSomething
这是一个错误,因为doSomething.jl
对Foo
一无所知。
julia> include("main.jl");
ERROR: LoadError: LoadError: LoadError: UndefVarError: Foo not defined
Stacktrace:
[1] include_from_node1(::String) at ./loading.jl:576
[2] include(::String) at ./sysimg.jl:14
[3] include_from_node1(::String) at ./loading.jl:576
[4] eval(::Module, ::Any) at ./boot.jl:235
[5] _require(::Symbol) at ./loading.jl:490
[6] require(::Symbol) at ./loading.jl:405
[7] include_from_node1(::String) at ./loading.jl:576
[8] include(::String) at ./sysimg.jl:14
while loading ~/Desktop/doSomething.jl, in expression starting on line 1
while loading ~/Desktop/FooModule.jl, in expression starting on line 6
while loading ~/Desktop/main.jl, in expression starting on line 1
如何解决此问题?
答案 0 :(得分:6)
只需将include("doSomething.jl")
移动到函数的原始位置,即在类型定义之后的之后。您可以将include
视为将代码复制粘贴到文件中。