5

NInject を使用して IEnumerable のバインドを設定する場合、IEnumerable を直接要求すると機能しますが、別のバインドされたオブジェクトが IEnumerable を必要とする場合は機能しません。これは設計によるものですか?

class Program {
    static void Main(string[] args){
        var k = new StandardKernel();
        k.Bind<IEnumerable<int>>().ToMethod(GetInts);
        k.Bind<IFoo>().To<Foo>(); //Has an IEnumberable<int> constructor arg
        var works = k.Get<IEnumerable<int>>(); //returns the array of ints
        var tst = k.Get<IFoo>(); //Empty integer array is passed in by ninject???
        tst.Get(); //returns an empty integer array????
        return;
    }

    public static int[] GetInts(IContext ctx){
        return new int[] {1,2,3,4,5};
    }
}


public interface IFoo{
    IEnumerable<int> Get();
}


public class Foo : IFoo{
    private int[] _vals;

    public Foo(IEnumerable<int> vals){
        _vals = vals.ToArray();
    }

    public IEnumerable<int> Get(){
        return _vals;
    }
}
4

1 に答える 1

4

マルチインジェクションが発生しています。

バインディングに明示的な Get を追加することでオーバーライドできます。

k.Bind<IFoo>().To<Foo>()
    .WithConstructorArgument( "vals", ctx=>ctx.Kernel.Get<IEnumerable<int>>());

(ただし、ソースを見れば、マルチ インジェクションを抑制する方法が見つかるはずです。)

于 2013-04-26T22:11:08.357 に答える