长话短说,我正在创建一个看起来有点像这样的工厂:
public static ITag GetByTagName(string tagName)
{
tagName = tagName.ToLower();
switch (tagName)
{
case "devicevar":
return new DeviceVar();
case "devicefilter":
return new DeviceFilter();
}
return null;
}但是,我还需要一个检查tagName是否对应于ITag的方法。实际上,我正在检查GetByTagName是否返回null,而不实际运行它:
private List<string> tagNames = new List<string> { "devicevar", "devicefilter" };
public static bool IsValidTagName(string tagName)
{
return tagName.Contains(tagName);
}看到我们有什么丑陋的复制了吗?我不想两次为tagName指定可能的值。我总是可以更改我的方法,以便它使用工厂尝试并实例化一个ITag,如果它返回null,那么我知道它不是一个有效值。但这似乎是浪费:
public static bool IsValidTagName(string tagName)
{
return GetByTagName(tagName) != null;
}一定有更好的办法
注:
我有一个很好的理由来做这个检查,但事实并非如此。
“如果我给它这个字符串,GetByTagName会返回一个ITag吗?是的?好的,打电话给GetByTagName”
发布于 2013-08-27 10:05:59
您可以创建Dictionary<string, Type>类型的字典,它将标记类型映射到它们的名称。
Dictionary<string, Type> tags = new Dictionary<string, Type>() {
{ "devicevar", typeof(DeviceVar) },
{ "devicefilter", typeof(DeviceFilter) }
};使用ContainsKey检查名称是否有效:
public static bool IsValidTagName(string tagName)
{
return tags.ContainsKey(tagName);
}使用Activator创建实例:
public static ITag GetByTagName(string tagName)
{
tagName = tagName.ToLower();
if (!IsValidTagName(tagName))
throw new ArgumentException(); // or return null
return (ITag)Activator.CreateInstance(tags[tagName]);
}更新(为了性能)而不是在字典中存储类型,在那里存储创建方法:
var tagsFactory = new Dictionary<string, Func<ITag>>() {
{ "devicevar", _ => new DeviceVar() },
{ "devicefilter", _ => new DeviceFilter() }
};得到的标签看起来如下:
return tagsFactory[tagName]();发布于 2013-08-27 10:22:02
如果tagName总是与TypeName匹配,则不能使用任何字典,只需按以下方式编写
public static ITag GetByTagName(string tagName)
{
var type = typeof(ITag).Assembly.GetTypes().SingleOrDefault(t => string.Equals(t.Name, tagName, StringComparison.OrdinalIgnoreCase));
if (type == null)
return null;
return (ITag) Activator.CreateInstance(type);
}
public static bool IsValidTagName(string tagName)
{
return GetByTagName(tagName) != null;
}如果您的类不在同一个程序集中,则应该修改此代码。
此选项的优点是它适用于资产中的任何类,您不需要在任何地方枚举它们。
https://stackoverflow.com/questions/18462437
复制相似问题