zoukankan      html  css  js  c++  java
  • 转(Check Null Before Adding into list)

    http://codereview.stackexchange.com/questions/3290/check-null-before-adding-into-list
    Is there anyway to refactor this ?

     public IEnumerable<Option> Options
        {
            get
            {
                {
                    List<Option> ListOption = new List<Option>();
    
                    if (!String.IsNullOrEmpty(Option1)) 
                    {
                        ListOption.Add(new Option() {Name=Option1 });
                    }
                    if (!String.IsNullOrEmpty(Option2))
                    {
                        ListOption.Add(new Option() { Name = Option2 });
                    }
                    if (!String.IsNullOrEmpty(Option3))
                    {
                        ListOption.Add(new Option() { Name = Option3 });
                    }
                    if (!String.IsNullOrEmpty(Option4))
                    {
                        ListOption.Add(new Option() { Name = Option4 });
                    } 
    
                    return ListOption;
                }
            }
        }
    
        public class Option
        {
            public string Name { get; set; }
        }
    

      

    ==>

    //This is a bit neater:
    List<Option> ListOption = new List<Option> { };
    Action add = x => { if (!String.IsNullOrEmpty(x)) ListOption.Add(new Option { Name = x }); }
    add(Option1);
    add(Option2);
    add(Option3);
    add(Option4);
    return ListOption;
    
    //This is perhaps even better:
    return (new string[] {Option1, Option2, Option3, Option4})
           .Where(x => !String.IsNullOrEmpty(x))
           .Select(x => new Option { Name = x })
           .ToList();
    
    //here's a version using a standard looping mechanism
    static List<Option> GetNonNullOptions(params string[] options)
    {
        var results = new List<Option>();
        if (options != null)
        {
            foreach (var option in options)
            {
                if (option != null)
                {
                    results.Add(new Option { Name = option });
                }
            }
        }
        return results;
    }
    
    //Leaving you to do something like this:
    var nonNullOptions = GetNonNullOptions(Option1, Option2, Option3, Option4);
    //Notice that I only check for null value items, as an empty string and a null value are two different things.
    
    //This is a good opportunity to use the yield operator:
    public IEnumerable<Option> Options
    {
        get
        {
            if (!string.IsNullOrEmpty(Option1)) yield return new Option{Name=Option1};
            if (!string.IsNullOrEmpty(Option2)) yield return new Option{Name=Option2};
            if (!string.IsNullOrEmpty(Option3)) yield return new Option{Name=Option3};
            if (!string.IsNullOrEmpty(Option4)) yield return new Option{Name=Option4};
        }
    }
    

      

  • 相关阅读:
    esDSLindex管理操作相关
    esDSL系统和集群运维相关
    git无法访问或者git访问超慢解决方案
    Java 多线程的一次整理
    记一次 Java 导出大批量 Excel 优化
    16个经典面试问题回答思路
    B树索引
    在Java中,为什么"100==100"为true,而"1000==1000"为false?
    explain详解
    字符串常量池和基本数据类型的包装类常量池
  • 原文地址:https://www.cnblogs.com/dennysong/p/3678623.html
Copyright © 2011-2022 走看看