Связанные не явные выражения в Swift 5.4

от автора

В Swift 5.4: не явные выражения для членов классов (также известные как «точечный синтаксис») теперь могут использоваться даже при обращении к свойству или методу в результате такого выражения, пока окончательный тип возвращаемого значения остается прежним.

Обратите внимание, что на момент написания статьи Swift 5.4 находится в стадии бета-тестирования в качестве части Xcode 12.5.

На практике это означает, что всякий раз, когда мы создаем объект или значение с помощью статического API, или при обращении обращении к перечисляемому типу, мы теперь можем напрямую вызвать метод или свойство в этом экземпляре класса, и компилятор по-прежнему сможет вывести тот тип, к которому мы обращаемся.

Например, при создании экземпляра UIColor с использованием одного из встроенных статических API-интерфейсов, предоставленных в качестве части системы, мы теперь можем легко изменить альфа-компонент такого цвета без необходимости явно ссылаться на сам UIColor в таких ситуациях, как:

// In Swift 5.3 and earlier, an explicit type reference is always // required when dealing with chained expressions: let view = UIView() view.backgroundColor = UIColor.blue.withAlphaComponent(0.5) ...  // In Swift 5.4, the type of our expression can now be inferred: let view = UIView() view.backgroundColor = .blue.withAlphaComponent(0.5) ...

Конечно, вышеупомянутый подход также работает при использовании наших собственных статических API, например, любых пользовательских определений UIColor, которые мы добавили с помощью расширения:

extension UIColor {     static var chiliRed: UIColor {         UIColor(red: 0.89, green: 0.24, blue: 0.16, alpha: 1)     } }  let view = UIView() view.backgroundColor = .chiliRed.withAlphaComponent(0.5) ...

Возможно, даже более интересным является то, какие двери открывает эта новая возможность с точки зрения дизайна API. В качестве примера, в «Легком дизайне API в Swift» мы рассмотрели следующий стиль API, включающий расширение структуры с помощью статических методов и свойств, что позволяет нам использовать ее способом, подобным типу перечисления:

extension ImageFilter {     static var dramatic: Self {         ImageFilter(             name: "Dramatic",             icon: .drama,             transforms: [                 .portrait(withZoomMultipler: 2.1),                 .contrastBoost,                 .grayScale(withBrightness: .dark)             ]         )     } }

При использовании Swift 5.4 (или более поздних версий в будущем) мы могли бы добавить что-то вроде такого, что позволяет нам легко объединить два экземпляра ImageFilter, путем объединения их .transforms:

extension ImageFilter {     func combined(with filter: Self) -> Self {         var newFilter = self         newFilter.transforms += filter.transforms         return newFilter     } }

С учетом вышеизложенного теперь мы сможем работать с фильтрами, которые комбинируются динамически. Теперь мы можем использовать тот же упрощенный точечный синтаксис, который раньше мог быть применен только к предварительно определенному фильтру.

let filtered = image.withFilter(.dramatic.combined(with: .invert))

Довольно круто! Я собираюсь продолжить изучение того, какие API-интерфейсы позволяет мне разрабатывать эта новая языковая функциональность, и, конечно же, продолжу делиться своими знаниями с вами в будущих статьях.

ссылка на оригинал статьи https://habr.com/ru/post/552286/


Комментарии

Добавить комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *