12

問題

循環要求を実行しようとしたときに、Lua 5.1 から次のエラーを回避するにはどうすればよいですか?

$ lua main.lua 
lua: ./bar.lua:1: loop or previous error loading module 'foo'
stack traceback:
    [C]: in function 'require'
    ./bar.lua:1: in main chunk
    [C]: in function 'require'
    ./foo.lua:1: in main chunk
    [C]: in function 'require'
    main.lua:1: in main chunk
    [C]: ?

ファイル構造

main.lua

require "foo"
require "bar"
print (Foo.getName())
print (Bar.getName())

foo.lua

require 'bar'
Foo = {}
Foo.name = 'foo'

function Foo:getName()
    return Foo.name .. Bar.name
end

bar.lua

require 'foo'
Bar = {}
Bar.name = 'bar'

function Bar:getName()
    return Bar.name .. Foo.name
end

期待される出力

$ lua main.lua 
foobar
barfoo
4

2 に答える 2

14

この問題を解決する別の方法は、コードの構造を変更し、「相互」機能を 3 番目のモジュールに抽出するFooことBarです。

于 2012-12-20T10:18:31.893 に答える
13

解決

main.lua

Foo = Foo or require "foo"
Bar = Bar or require "bar"
print (Foo.getName())
print (Bar.getName())

foo.lua

Foo = {}
Bar = Bar or require "bar"
Foo.name = 'foo'

function Foo:getName()
    return Foo.name .. Bar.name
end

return Foo

bar.lua

Bar = {}
Foo = Foo or require "foo"
Bar.name = 'bar'

function Bar:getName()
    return Bar.name .. Foo.name
end

return Bar

説明

グローバル変数を設定しているので、別の require を試みる前に、ファイルがすでに必要であるかどうか (つまり、グローバルが既に定義されているかどうか) を確認できます。

Bar = Bar or require "bar"

次に、 Barbar.luaの定義を返す必要があります。

Bar = {}
-- ...
return Bar

定義されてbar.luaいると予想されるため、これで問題が完全に解決されるわけではありません。Fooこれを解決するには、同じ名前のダミー変数を定義します。

Foo = {}
Bar = Bar or require "bar"

Fooこれは、関数が呼び出されたときに toの使用を延期しているためにのみ可能です。Foo.nameのスコープ内から呼び出す場合はbar.lua、同じ循環依存の問題が発生します。

于 2012-12-20T03:16:02.760 に答える