我的问题涉及一系列通用方法中的类型检查。假设我有一个扩展方法,它尝试将字节数组转换为 int、decimal、string 或 DateTime。
public static T Read<T>(this ByteContainer ba, int size, string format) where T : struct, IConvertible
{
var s = string.Concat(ba.Bytes.Select(b => b.ToString(format)).ToArray());
var magic = FromString<T>(s);
return (T)Convert.ChangeType(magic, typeof(T));
}
这调用了一个名为 FromString 的方法,该方法将连接的字符串转换为特定类型。不幸的是,业务逻辑完全依赖于类型 T。所以我最终得到了一个巨大的 if-else 块:
private static T FromString<T>(string s) where T : struct
{
if (typeof(T).Equals(typeof(decimal)))
{
var x = (decimal)System.Convert.ToInt32(s) / 100;
return (T)Convert.ChangeType(x, typeof(T));
}
if (typeof(T).Equals(typeof(int)))
{
var x = System.Convert.ToInt32(s);
return (T)Convert.ChangeType(x, typeof(T));
}
if (typeof(T).Equals(typeof(DateTime)))
... etc ...
}
在这一点上,我更喜欢具有相同名称和不同返回类型的多个方法,类似于以下内容:
// <WishfulThinking>
private static decimal FromString<T>(string s)
{
return (decimal)System.Convert.ToInt32(s) / 100;
}
private static int FromString<T>(string s)
{
return System.Convert.ToInt32(s);
}
// </WishfulThinking>
...但我意识到这是无效的,因为 T 不能被限制为特定类型,没有它,所有方法都将具有相同的冲突签名。
有没有一种可行的方法来实现 FromString 而无需过多的类型检查?或者是否有更好的方法来完全解决这个问题?