use*_*153 3 c# generics types list
private void listHelper (int listSize, ref Object taker, Object giver, Type type)
{
if (listSize == 0)
{
taker = null;
}
else
{
taker = new List<type>(listSize);
giverType tempGiver;
for (int i = 0; i < listSize; i++)
{
type= new type();
tempGiver.value = giver[i];
taker.Add(tempGiver);
}
}
}
Run Code Online (Sandbox Code Playgroud)
这是我的代码.我试图将一个类型参数传递给私有方法来声明泛型类型列表......但我不知道该怎么做.
参数接受者是一个列表.在这种情况下,接受者正在存储一般类型的对象.参数类型是泛型的类型.
我在互联网上搜索了一段时间.我仍然不确定如何做到这一点.
lc.*_*lc. 10
尝试制作通用方法:
private void listHelper<T> (int listSize, out List<T> taker, IList<T> giver)
{
if (listSize == 0)
{
taker = null;
}
else
{
taker = new List<T>(listSize);
for (int i = 0; i < listSize; i++)
{
taker.Add(giver[i]);
}
}
}
Run Code Online (Sandbox Code Playgroud)
此外,我建议使用out
而不是ref
(我已经完成),因为你总是taker
在返回之前分配一个值.这允许调用代码在调用方法之前不必分配虚拟值.
或者更好的是,你应该只返回列表!
private List<T> listHelper<T> (int listSize, IList<T> giver)
{
List<T> taker;
...
return taker;
}
Run Code Online (Sandbox Code Playgroud)
注意,如果你所有的方法都在做的是将所有元素复制giver
到taker
(也就是说,指定listSize
实际上只是编码C的延迟习惯,并且总是等于元素的数量giver
),你可以替换giver.Count
或者只做:
private List<T> listHelper<T> (IList<T> giver)
{
return giver.Any() ? giver.ToList() : null;
}
Run Code Online (Sandbox Code Playgroud)
当然,如果listSize
真的是"从前面开始返回的元素数量giver
",你可以这样做:
private List<T> listHelper<T> (IList<T> giver, int numElements)
{
return giver.Any() ? giver.Take(numElements).ToList() : null;
}
Run Code Online (Sandbox Code Playgroud)
实际上,进一步阅读您的问题,看起来您想要实例化某种类型的新对象并将其value
属性设置为该项目giver
.那么这个怎么样(当然我假设你的taker
对象很多,并且你有一个ITaker<U>
指定字段/属性的接口public U value
):
private List<T<U>> listHelper<T, U> (IList<U> giver) where T : ITaker<U>, new()
{
return giver.Any() ? giver.Select(g => new T<U>() {value = g}).ToList() : null;
}
Run Code Online (Sandbox Code Playgroud)