有时,看到类似这样的C#语句:

   1:          private static bool TraditionalVerify(int number)
   2:          {
   3:              if ((number > 0) && (number >= 10) && (number % 2 > 0) && (number * 2 > 100))
   4:              {
   5:                  return true;
   6:              }
   7:              return false;
   8:          }

        这里只有四个条件,假设这里有超过四个或更多时,那时代码转行时可读性就更差了。我们可以将上面的代码改成:

   1:          /// <summary>
   2:          /// Demo for use Func combine conditions
   3:          /// </summary>
   4:          /// <param name="number">need verify number</param>
   5:          /// <returns>true</returns>
   6:          /// <seealso cref="http://msdn.microsoft.com/en-us/library/kdxe4x4w.aspx"/>
   7:          /// <remarks>author Petter Liu http://wintersun.cnblogs.com</remarks>
   8:          private static bool UseFunc(int number)
   9:          {
  10:              var conditionlist = new List<Func<bool>>()
  11:              {
  12:                   () => number > 0,
  13:                   () => number >= 10,
  14:                   () => number % 2 > 0,
  15:                   () => number * 2 > 100
  16:              };
  17:   
  18:              return conditionlist.TrueForAll(foo => foo.Invoke());
  19:          }

       注意粗体部分的代码,这样看上去更容易阅读。你可增多更多的条件判读语句。实际情况下,还可以考虑Strategies来重构代码。

       希望对您开发有帮助!


作者:Petter Liu
出处:http://www.cnblogs.com/wintersun/
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
该文章也同时发布在我的独立博客中-Petter Liu Blog

posted on 2011-02-12 11:22  PetterLiu  阅读(1206)  评论(1编辑  收藏  举报