我有一个简单的帮助器类,用于构建一个简单的逗号分隔字符串。
private string AddcsvString(string s)
{
if(string.IsNullOrWhiteSpace(this.Value))
{
return s;
}
else
{
return this.Value + "," + s;
}
}
我也有一个调用此
的通用方法public void Add<T>(T s) where T: struct
{
this.Value = AddcsvString(s.ToString());
}
我想为通用List添加重载
public void Add<T>(IEnumerable<T> values)where T:struct
{
foreach (T t in values)
{
Add(t.ToString());
}
}
但是任何调用它的尝试都称为第一种泛型方法。所以我最终将第二个泛型方法重命名为AddAll。最后,我认为这是解决这个问题的正确方法,但是想知道是否可以将两者都用于未来参考。
- 编辑 这是不起作用的情况
CsvString test = new CsvString();
string result;
test.Add(1);
test.Add('2');
test.Add("3");
result = test.ToString(); // result = "1,2,3"
CsvString test2 = new CsvString();
List<long> aList = new List<long>();
string result2;
aList.Add(1);
aList.Add(2);
aList.Add(3);
test2.Add(aList); //line doesn't compile
- 编辑2 我找到了第二种解决方案(虽然下面的JoshE因为回答这个问题而获得赞誉,谢谢顺便说一下)。 我将第二种方法更改为此
public SWcsvString Add<T,K>(T values)where T: IEnumerable<K> where K: struct
{
foreach (K k in values)
{
Add(k.ToString());
}
return this;
}
和对此的调用
test2.Add<IEnumerable<long>,long>(aList);
答案 0 :(得分:1)
尝试删除约束where T : struct
,我认为您将获得正确的行为。
IEnumerable<char> <==> String
,因为string
只是char[]
。由于string
不是真正一个值对象,因此重载解析几乎总是支持第一种方法来避免将字符串转换为IEnumerable<char>
的装箱/取消装箱操作。 (我猜你已经尝试用"foo"
和IEnumerable<bar>
调用它,其中bar
是一个结构体。