Язык программирования C#9 и платформа .NET5
{HelpLink = "http://www.CarsRUs.com",Data = {{"TimeStamp",$"The car exploded at {DateTime.Now}"},{"Cause","You have a lead foot."}}};}Console.WriteLine("=> CurrentSpeed = {0}", CurrentSpeed);}}С целью успешного прохода по парам "ключ-значение" добавьте директиву
для пространства именusing, т.к. в файле с операторами верхнего уровня будет применяться типSystem.Collections:DictionaryEntryusing System.Collections;Затем обновите логику в блоке
, чтобы обеспечить проверку значения, возвращаемого из свойстваcatch, на равенствоData(т.е. стандартному значению). После этого свойстваnullиKeyтипаValueиспользуются для вывода специальных данных на консоль:DictionaryEntrycatch (Exception e){...Console.WriteLine("\n-> Custom Data:");foreach (DictionaryEntry de in e.Data){Console.WriteLine("-> {0}: {1}", de.Key, de.Value);}}Вот как теперь выглядит финальный вывод программы:
***** Simple Exception Example *****=> Creating a car and stepping on it!Jamming...=> CurrentSpeed = 30=> CurrentSpeed = 40=> CurrentSpeed = 50=> CurrentSpeed = 60=> CurrentSpeed = 70=> CurrentSpeed = 80=> CurrentSpeed = 90*** Error! ***Member name: Void Accelerate(Int32)Class defining member: SimpleException.CarMember type: MethodMessage: Zippy has overheated!Source: SimpleExceptionStack: at SimpleException.Car.Accelerate(Int32 delta) ...at SimpleException.Program.Main(String[] args) ...Help Link: http://www.CarsRUs.com-> Custom Data:-> TimeStamp: The car exploded at 3/15/2020 16:22:59-> Cause: You have a lead foot.***** Out of exception logic *****Свойство
удобно в том смысле, что оно позволяет упаковывать специальную информацию об ошибке, не требуя построения нового типа класса для расширения базового классаData. Тем не менее, каким бы полезным ни было свойствоException, разработчики все равно обычно строят строго типизированные классы исключений, которые поддерживают специальные данные, применяя строго типизированные свойства.DataТакой подход позволяет вызывающему коду перехватывать конкретный тип, производный от
, а не углубляться в коллекцию данных с целью получения дополнительных деталей. Чтобы понять, как это работает, необходимо разобраться с разницей между исключениями уровня системы и уровня приложения.ExceptionИсключения уровня системы (System.SystemException)
В библиотеках базовых классов .NET 5 определено много классов, которые в конечном итоге являются производными от
.System.ExceptionНапример, в пространстве имен
определены основные объекты исключений, такие какSystem,ArgumentOutOfRangeException,IndexOutOfRangeExceptionи т.п. В других пространствах имен есть исключения, которые отражают поведение этих пространств имен. Например, вStackOverflowExceptionопределены исключения, связанные с печатью, вSystem.Drawing.Printing— исключения, возникающие во время ввода-вывода, вSystem.IO— исключения, специфичные для баз данных, и т.д.System.DataИсключения, которые генерируются самой платформой .NET 5, называются системными исключениями. Такие исключения в общем случае рассматриваются как неисправимые фатальные ошибки. Системные исключения унаследованы прямо от базового класса
, который в свою очередь порожден отSystem.SystemException(а тот — от классаSystem.Exception):System.Objectpublic class SystemException : Exception{// Various constructors.}Учитывая, что тип
не добавляет никакой дополнительной функциональности кроме набора специальных конструкторов, вас может интересовать, по какой причине он вообще существует. Попросту говоря, когда тип исключения является производным отSystem.SystemException, то есть возможность выяснить, что исключение сгенерировала исполняющая среда .NET 5, а не кодовая база выполняющегося приложения. Это довольно легко проверить, используя ключевое словоSystem.SystemException:is// Верно! NullReferenceException является SystemException.