Привет! Меня немного смущает, как компилятор C# выполняет свою оптимизацию.
Я написал следующий метод получения для создания «ленивой» инициализации и значения по умолчанию в случае null:
Помощник статического класса:
private static string host;
public static string Host
{
get
{
return host ?? (host= (ConfigurationManager.AppSettings["Host"] ?? "host.ru"));
}
}
Вот результат дизассемблирования Reflector:
public static string Host
{
get
{
if (Helper.host == null)
{
string host = Helper.host;
}
return (Helper.host = ConfigurationManager.AppSettings["Host"] ?? "host.ru");
}
}
Похоже, это будет работать не так, как предполагалось...
ОБНОВЛЕНИЕ
private static string host;
public static string Host
{
get
{
return host ?? (host = (GetVal() ?? "default"));
}
}
static void Main(string[] args)
{
Console.WriteLine(Host);
host = "overwritten";
Console.WriteLine(Host);
}
static string GetVal()
{
return "From config";
}
Работает правильно (из конфигурации перезаписано), но Reflector показывает то же самое:
public static string Host
{
get
{
if (Program.host == null)
{
string host = Program.host;
}
return (Program.host = GetVal() ?? "default");
}
}
Подробнее здесь: https://stackoverflow.com/questions/429 ... -reflector
Оптимизация компиляции C#: оператор объединения null – ОБНОВЛЕНО – Ошибка Reflector? ⇐ C#
-
- Похожие темы
- Ответы
- Просмотры
- Последнее сообщение