Microsoft выпустила предварительную версию Visual studio 2015 и .Net 4.6 для разработчиков. В новом C# 6.0 несколько новых возможностей, которые могут облегчить кодинг.
В этой статье рассмотрены новые возможности языка C# 6.0. Скачать новую VS можно по ссылке:
Microsoft Visual Studio Ultimate 2015 Preview
Инициализация свойств со значениями
В C# 6.0 мы можем инициализировать свойства со значениями, написав справа от них их значение. Это поможет избежать ошибки с null и пустыми значениями свойства.
Раньше:
public int Id { get; set; }
public string FirstName { get; set; }
Теперь:
public int Id { get; set; } = 1001;
public string FirstName { get; set; } = "Srinivas";
Интерполяция строк
Каждый день нам приходится сталкиваться с конкатенацией строк. Кто-то в основном использует оператор “+”, кто-то — метод string.Format(). Мне лично по душе string.Format(). Но проблемы с ним всем известны: при слишком большом количестве параметров тяжело понимать, что означают каждое число – {1}, {2}, {3}. В C# 6.0 придумали новую возможность, которая должна объединить достоинства обоих методов.
Раньше:
name = string.Format("Employee name is {0}, located at {1}", emp.FirstName, emp.Location);
Теперь:
name = $"Employee name is {emp.FirstName}, located at {emp.Location}";
По просьбе трудящихся IL код
IL_0000: nop
IL_0001: ldstr "Ivan"
IL_0006: stloc.0
IL_0007: ldstr "Moscow"
IL_000c: stloc.1
IL_000d: ldstr "Employee name is {0}, located at {1}"
IL_0012: ldloc.0
IL_0013: ldloc.1
IL_0014: call string [mscorlib]System.String::Format(string, object, object)
IL_0019: stloc.2
IL_001a: ret
Так же можно использовать условия:
name = $"Employee name is {emp.FirstName}, located at {emp.Location}. Age of employee is
{(emp.Age > 0) ? emp.Age.ToString() : "N/A"}";
Использование лямбда-выражений
В C# 6.0 свойства и методы можно определять через лямбда-выражения. Это сильно уменьшает количество кода.
Раньше:
public string[] GetCountryList()
{
return new string[] { "Russia", "USA", "UK" };
}
Теперь:
public string[] GetCountryList() => new string[] { "Russia", "USA", "UK" };
Импорт статических классов
Все статические члены класса могут быть определены с помощью другого статического класса. Но нам приходится постоянно повторять имя данного статического класса. При большом количестве свойств приходится много раз повторять одно и то же.
В C# 6.0 появилась возможность импортировать с помощью ключевого слова using статические классы. Рассмотрим все на примере использования библиотеки Math:
Раньше
double powerValue = Math.Pow(2, 3);
double roundedValue = Math.Round(10.6);
Теперь:
using System.Math;
double powerValue = Pow(2, 3);
double roundedValue = Round(10.6);
Это можно использовать не только внутри класса, но и при выполнении метода:
Раньше:
var employees = listEmployees.Where(i => i.Location == "Bangalore");
Теперь:
using System.Linq.Enumerable;
var employees = Where(listEmployees, i => i.Location == "Bangalore");
Null-условный оператор
C# 6.0 вводит новый так называемый Null-условный оператор (?.), который будет работать поверх условного оператора (?:). Он призван облегчить проверку на NULL значения.
Он возвращает null значения, если объект класса, к которому применен оператор, равен null:
var emp = new Employee()
{
Id = 1,
Age = 30,
Location = "Bangalore",
Department = new Department()
{
Id = 1,
Name = "IT"
}
};
Раньше:
string location = emp == null ? null : emp.Location;
string departmentName = emp == null ? null : emp.Department == null ? null : emp.Department.Name;
Теперь:
string location = emp?.Location;
string departmentName = emp?.Department?.Name;
nameof оператор
В C# 6.0 оператор nameof будет использоваться, чтобы избежать появления в коде строковых литералов свойств. Этот оператор возвращает строковый литерал передаваемого в него элемента. В качестве параметра можно передать любой член класса или сам класс.
var emp = new Employee()
{
Id = 1,
Age = 30,
Location = "Moscow",
Department = new Department()
{
Id = 1,
Name = "IT"
}
};
Response.Write(emp.Location); //result: Moscow
Response.Write(nameof(Employee.Location)); //result: Location
Await в catch и finally блоках
До C# 6.0 нельзя было использовать в блоках catch и final оператор await. Сейчас такая возможность появилась. Ее можно будет использовать для освобождения ресурсов или для ведения логов ошибок.
public async Task StartAnalyzingData()
{
try
{
// код
}
catch
{
await LogExceptionDetailsAsync();
}
finally
{
await CloseResourcesAsync();
}
}
Фильтры исключений
Фильтры исключений были в CLR, и они доступны в VB, но их не было в C#. Теперь данная возможность появилась, и можно накладывать дополнительный фильтр на исключения:
try
{
//Вызываем исключение
}
catch (ArgumentNullException ex) if (ex.Source == "EmployeeCreation")
{
//Нотификация об ошибке
}
catch (InvalidOperationException ex) if (ex.InnerException != null)
{
//Нотификация об ошибке
}
catch (Exception ex) if (ex.InnerException != null)
{
//Сохраняем данные в лог
}
Инициализация Dictionary
В C# 6.0 добавлена возможность инициализации Dictionary по ключу значения. Это должно упростить инициализацию словарей.
Например, для JSON объектов:
var country = new Dictionary<int, string>
{
[0] = "Russia",
[1] = "USA",
[2] = "UK",
[3] = "Japan"
};
В C# 6.0 много синтаксических изменений и новых возможностей. Также Microsoft улучшает новый компилятор в плане производительности.
P.S. Новые возможности описаны на текущую версию компилятора, к выходу финальной версии синтаксис может измениться.