2

我有一个名为 NTree 的类:

class NTree<T>
{

    delegate bool TreeVisitor<T>(T nodeData);

    public NTree(T data)
    {
        this.data = data;
        children = new List<NTree<T>>();
        _stopTraverse = false;
    }

        ...

    public void Traverse(NTree<T> node, TreeVisitor<T> visitor)
    {
        try
        {
            _stopTraverse = false;
            TraverseInternal(node, visitor);
        }
        finally
        {
            _stopTraverse = false;
        }
    }

    private void TraverseInternal(NTree<T> node, TreeVisitor<T> visitor)
    {
        if (_stopTraverse)
            return;

        if (!visitor(node.data))
        {
            _stopTraverse = true;
        }
        foreach (NTree<T> kid in node.children)
            TraverseInternal(kid, visitor);
    }

当我尝试将 Traverse 与匿名委托一起使用时,我得到:

参数“2”:无法从“匿名方法”转换为“NisConverter.TreeVisitor”

编码:

tTable srcTable = new tTable();
DataRow[] rows;
rootTree.Traverse(rootTree, delegate(TableRows tr)
    {
        if (tr.TableName == srcTable.mappingname)
        {
            rows = tr.Rows;
            return false;
        }
    });

然而,这不会产生错误:

    static bool TableFinder<TableRows>(TableRows tr)
    {
        return true;
    }

...

rootTree.Traverse(rootTree, TableFinder);

我试图将“箭头括号”和所有内容都放在匿名委托中,但它不起作用。请帮我!

谢谢和BR-马蒂

4

2 回答 2

4

您发布的匿名委托缺少布尔值的返回(很可能是trueif(...)守卫为时的值false。因此,它的签名实际上是void (TableRow)而不是bool (TableRow),编译器无法进行转换。

所以语法应该是:

tTable srcTable = new tTable();  DataRow[] rows;  rootTree.Traverse(rootTree, delegate(TableRows tr) 
    { 
        if (tr.TableName == srcTable.mappingname) 
        { 
            rows = tr.Rows; 
            return false; 
        } 
        return true;
    });
于 2010-05-04T07:50:13.123 回答
1

TreeVisitor 的声明是错误的:它引入了一个新的类型参数(与 NTree 的声明冲突)。只需删除模板的东西,你会得到:

delegate bool TreeVisitor(T nodeData);

然后你可以拥有:

class X
{

    void T()
    {
        NTree<int> nti = new NTree<int>(2);

        nti.Traverse(nti, delegate(int i) { return i > 4; });

    }
}
于 2010-05-04T07:54:04.257 回答