C # Switch оператор возврата подходит для замены разрыва - PullRequest
29 голосов
/ 07 июля 2010

Является ли это подходящим способом обработки операторов переключения c # или все еще требуется явный разрыв? ссылка

  public static string ToRegistryString(AliceKey.AliceKeyPaths aliceKeyPath)
    {
     switch (aliceKeyPath)
        {
            case AliceKey.AliceKeyPaths.NET_CLR_DATA:
                return @"\.NET CLR Data\";
            case AliceKey.AliceKeyPaths.NET_CLR_NETWORKING:
                return @"\.NET CLR Networking\";
            case AliceKey.AliceKeyPaths.NET_DATA_PROVIDER_MSSQL:
                return @"\.NET Data Provider for SqlServer\";
            case AliceKey.AliceKeyPaths.NET_DATA_PROVIDER_ORACLE:
                return @"\.NET Data Provider for Oracle\";
         }
       return new string(new char[0]);
     }

Ответы [ 2 ]

40 голосов
/ 07 июля 2010

Отлично.Дело в том, что конец блока case должен быть недоступен - что он здесь, потому что вы вернулись.

Почему вы возвращаете new string(new char[0]), а не просто "" или string.Empty, хотя?Если вы пытаетесь каждый раз убедиться, что это другая строка, вы действительно столкнетесь с очень странным угловым случаем - несмотря на вызов new string(...), этот код всегда будет возвращать одну и ту же ссылку ...

Наконец: я бы предложил изменить этот блок переключателей / регистров на Dictionary<AliceKey.AliceKeyPaths, string>:

private static readonly Dictionary<AliceKey.AliceKeyPaths, string> RegistryMap =
    new Dictionary<AliceKey.AliceKeyPaths, string>
{
    { AliceKey.AliceKeyPaths.NET_CLR_DATA, @"\.NET CLR Data\" },
    { AliceKey.AliceKeyPaths.NET_CLR_NETWORKING, @"\.NET CLR Networking\" },
    // etc
};

public static string ToRegistryString(AliceKey.AliceKeyPaths aliceKeyPath)
{
    string value;
    return RegistryMap.TryGetValue(aliceKeyPath, out value) ? value : "";
}
5 голосов
/ 07 июля 2010

Вам не нужно специально использовать оператор break, который только меняет поток управления, поэтому goto или return должны работать.

См. MSDN для получения дополнительной информации: http://msdn.microsoft.com/en-us/library/06tc147t(VS.71).aspx

...