.net in C#

  • 本文关键字:in net c# .net
  • 更新时间 :
  • 英文 :


我有这个寄存器,它注册了我需要的所有对象:

public static class ObjectRegister
{
    public static List<IObject> RegisteredObjects = new List<IObject>();
    static ObjectRegister()
    {
        RegisteredObjects.Add(new Object1());
        RegisteredObjects.Add(new Object2());
        RegisteredObjects.Add(new Object3());
    }
}

接下来我有这个函数检查列表,如果列表中的项目通过测试,它创建一个对象实例并将其添加到列表中:

public static List<IObject> Scan(List<parametar> list)
    {
        List<IObject> neededObjects = new List<IObject>();
        foreach (IObject registeredObject in ObjectRegister.RegisteredObjects)
        {
            foreach (parametar param in list)
            {
                if (registeredObject.Test(param)) //returns true or false 
                {
                    neededObjects.Add(registeredObject.CreateInstance(param));
                }
            }
        }
        return connectedObjects;
    }

下面是Object1的CreateInstace方法:

public IObject CreateInstance(parametar param)
    {
        return new Object1(param);
    }

下面是构造函数:

public Object1(parametar newParam)
    {
        this.param = newParam;
    }

它一直在这一行显示StackOverflow异常:

this.param = newParam;

尝试了创建实例,默认构造函数,空对象等所有可能性,但都不起作用…什么好主意吗?

谢谢

编辑:Object1类的代码:

public class Object1: IObject
{
    public parametar param
    {
        get { return this.param; }
        set { this.param = value; }
    }
    internal Object1() { }
    public Object1(parametar newParam)
    {
        this.param = newParam;
    }        

    public bool test(parametar param)
    {
        // I do the propper checking of the param here, and return the result
    }

    public IObject CreateInstance(parametar param)
    {
        return new Object1(param);
    }
} 

这是你的问题,在Object1:

public parametar param { get { return this.param; } set { this.param = value; }

这个属性递归地调用自己——这就是为什么你会得到堆栈溢出。不要那样做。相反,您可能需要一个自动实现的属性:

public parameter param { get; set; }

或使用私有支持字段:

private parametar param;
public parametar Param { get { return param; } set { param = value; }

另外,我强烈建议您开始遵循。net命名约定,并注意类型和成员名的拼写。

所以你可能希望你的类被称为Parameter -尽管我个人至少会尝试使它更具有描述性,例如QueryParameter或类似的东西。同样,Object1不是一个语义上有意义的名称-我希望它不是您的真实代码中的名称。

最新更新