我不想说:
(trsaz != v1) && (trsaz != v2) && ...
我想要类似的东西:
trsaz != (v1, v4, v7, v11)
除了!=
之外还有其他可能吗?
答案 0 :(得分:12)
var badList = new[] { v1, v4, v7, v11 };
var result = !badList.Contains(trsaz);
答案 1 :(得分:2)
var excludeList = new[] { "v1", "v4", "v7", "v11" };
if(!excludeList.Contains(trsaz))
{
...
}
答案 2 :(得分:0)
实际上,我更喜欢为此创建一个小扩展方法:
public static bool IsIn<T>(this T obj, params T[] set) {
return set.Any(el => element.Equals(obj));
}
它封装了所有的黑魔法并使你的代码真正简洁,这是你的目标,显然:
if (!trsaz.IsIn(v1, v4, v7, v11)) {
// ...
}
如果机制不重要,隐藏机制总是好的,特别是在这种情况下,根本不需要使用任何机制,并且会使一些维护代码的人感到困惑。
答案 3 :(得分:0)
var result = (new[] {v1, v4, v7}).Every(o => o != trsaz);