我从下面的代码中得到各种编译错误。我有一个List设置,如下所示,我不太确定如何将项目添加到列表中。我不打算基本维护StockEntry类中设置的值,并使用类StockItem作为Count。使用... _stocks.Value.Count ++
public class StockEntry
{
public string Name;
public PeriodType Period;
public int Min;
public StockEntry(string Name, PeriodType Period, int Min)
{
this.Name = Name;
this.Period = Period;
this.Min = Min;
}
}
public class StockItem<T>
{
public T Value;
public StockItem() {}
public StockItem(T val) {Value = val;}
}
List<StockItem<StockEntry>> _stocks = new List<StockItem<StockEntry>>();
protected override void Initialize()
{
_stocks.Add(new StockItem(StockEntry("ABC", PeriodType.Minute, 5)));
_stocks.Add(new StockItem(StockEntry("ACE", PeriodType.Minute, 5)));
_stocks.Add(new StockItem(StockEntry("ACN", PeriodType.Minute, 5)));
}
答案 0 :(得分:3)
除了其他任何事情,这可能是问题所在:
_stocks.Add(new StockItem(StockEntry("ABC", PeriodType.Minute, 5)));
(和类似的行)。
StockItem
是一个泛型类,因此您需要指定类型参数:
_stocks.Add(new StockItem<StockEntry>(StockEntry("ABC", PeriodType.Minute, 5)));
如果您想避免这种有点冗余的规范,可以在非泛型类型中创建静态泛型方法:
// Overload StockItem<T> by generic arity
public static class StockItem
{
public static StockItem<T> Of(T item)
{
return new StockItem<T>(item);
}
}
然后:
_stocks.Add(StockItem.Of(StockEntry("ABC", PeriodType.Minute, 5)));
那就是说,为什么StockItem
首先需要通用并不是很清楚。我肯定会避免使用公共字段 - 至少使它成为一个自动实现的属性。 (理想情况下,IMO,使其成为由构造函数中设置的只读字段支持的只读属性,并删除无参数构造函数。但后来我是不可变性的粉丝。)同样,我将摆脱{{1中的公共字段}}
答案 1 :(得分:2)
我认为如果您在此行添加new
关键字:
_stocks.Add(new StockItem(StockEntry("ABC", PeriodType.Minute, 5)));
你的问题将得到解决。
_stocks.Add(new StockItem(new StockEntry("ABC", PeriodType.Minute, 5)));
答案 2 :(得分:0)
_stocks和Initialize需要成为一个类的一部分 - 它们目前不是。
据推测,您希望它们成为StockItem的一部分:
public class StockItem<T>
{
public T Value;
public StockItem() {}
public StockItem(T val) {Value = val;}
} // The class StockItem ends with this bracket