我想问问在C#方面比我强的人。
是否有可能减少以下代码
if(val > 20 && val < 40 )
...
else
if(val > 40 && val < 72 )
...
else
if(val > 72 && val < 88 )
...
else
...让我们假设我有超过10-11条if-else语句。
缩短上述代码的最好方法是什么?
我想到的是sql中的between。
发布于 2012-09-06 03:15:56
public static bool Between(this int source, int a, int b)
{
return source > a && source < b;
}然后,使用它:
if (val.Between(20, 40))
//...正如oɔɯǝɹ在他的评论中正确指出的那样,你可以更进一步,用一个通用的扩展方法来支持IComparable的所有实现者:
public static bool Between<T>(this T source, T a, T b) where T : IComparable<T>
{
return source.CompareTo(a) > 0 && source.CompareTo(b) < 0;
}发布于 2012-09-06 03:21:47
另一种方法是将范围存储在列表中,并使用Contains函数来确定val是否在范围内,但如果没有更多的信息,它看起来就像你能做到的一样短。
发布于 2012-09-06 03:22:23
你可以做一个介于,但它将是一样多,如果不是更多的输入来调用它。在这种情况下,如果您真的想要between所做的事情,那么您应该更简洁地使用:
if(val >= 20 && val <= 88)
{
if(val <= 40 )
...
else if(val <= 72 )
...
}
else
...请注意,我使用<=和>=来匹配between行为。但是,我假设您既不想为值做两件事,确切地说是40,也不想什么也不做(在您的问题中,什么都不会做)。
https://stackoverflow.com/questions/12288206
复制相似问题