如何在不改变 C# 功能的情况下尽可能减少代码中的分支?

How to reduce branches in my code as many as possible without changing functionalities in c#?

public static void addpatron()
    {
        Console.WriteLine("You have selected to add a Patron.");
        string first, last, city, state = "", street, email, temp;
        int zip = 0;
        long number = 0;
        Console.WriteLine("Please Provide a First Name: ");
        first = Console.ReadLine();
        Console.WriteLine("Please Provide a Last Name: ");
        last = Console.ReadLine();
        Console.WriteLine("Please Provide a Street Address: ");
        street = Console.ReadLine();
        Console.WriteLine("Please Provide a City Name: ");
        city = Console.ReadLine();
        Console.WriteLine("Please Provide a Email Id: ");
        email = Console.ReadLine();
        int f = 0;
        while (f == 0)
        {
            Console.WriteLine("Please Provide a State Name: ");
            state = Console.ReadLine();
            if (state.Length == 2)
            {
                Regex r = new Regex(@"([A-Za-z][A-Za-z])");
                Match m = r.Match(state);
                if (m.Success)
                    f = 1;
            }
        }
        while (f == 1)
        {
            Console.WriteLine("Please Provide a Zip Code: ");
            temp = Console.ReadLine();
            if (temp.Length == 5)
            {
                Regex r = new Regex(@"([0-9]{5})");
                Match m = r.Match(temp);
                if (m.Success)
                {
                    zip = int.Parse(temp);
                    if (zip / 10000 != 0)
                        f = 0;
                }
            }
        }
        while (f == 0)
        {
            Console.WriteLine("Please Provide a Mobile Number: ");
            temp = Console.ReadLine();
            if (temp.Length == 10)
            {
                Regex r = new Regex(@"([0-9]{10})");
                Match m = r.Match(temp);
                if (m.Success)
                {
                    number = long.Parse(temp);
                    if (number / 100000000 != 0)
                        f = 1;
                }
            }
        }

        MainClass.patron.Add(MainClass.user, new Info { firstname = first, lastname = last, street = street, state = state, city = city, zip = zip, phone = number, email = email });
        displayUser.display(MainClass.user);
        MainClass.user++;
        MainClass.Menu();
    }

有一些方法可以缩短您的代码:

  1. 您可以使用 do {} while (condition); 循环。这样就可以决定输入后是否退出循环。

  2. 不需要一个变量,决定是否停止循环。您可以在循环条件中检查所有条件(在您的情况下非常容易)。

  3. 您可以使用 ^ = 字符串开头和 $= 字符串锚点结尾以及 {5} 作为正则表达式检查字符串的长度比赛的长度。

  4. 您也可以简化正则表达式以忽略大小写。

  5. 您的除法运算似乎只是为了检查输入的第一个数字是否与 0 不同。您也可以使用正则表达式进行检查。

  6. 可以使用静态Regex.IsMatch()方法,即returnstruefalse.

例如检查状态

do {
   Console.WriteLine("Please Provide a State Name: ");
   state = Console.ReadLine();
} while (!RegEx.IsMatch(state, @"^[a-z]{2}$", RegexOptions.IgnoreCase)) 

检查邮政编码。 int.TryParse() 只会被执行,如果 Regex.Match() returns true 是一种方便的方式,解析并赋值给表达式内部。

do {
   Console.WriteLine("Please Provide a ZIP Code: ");
   tmp = Console.ReadLine();
} while (!(RegEx.IsMatch(tmp, @"^[1-9][0-9]{4}$") && int.TryParse(tmp, out zip)));