Новости
10.03.2023
Книга «Грокаем функциональное мышление»
Отдел маркетинга все еще должен согласовывать действия с разработчиками
Абстрактный барьер, который позволил предоставить удобный API для отдела маркетинга, работал, но не так, как было задумано. Да, большая часть работы могла выполняться без координации, но часто отдел маркетинга предлагал команде разработчиков добавить в API новые функции, которые нельзя было выполнить средствами существующего API. Примеры таких запросов:
Подобных запросов очень много, и они продолжают поступать. Все запросы очень похожи — даже код их реализации был похожим. Разве абстрактный барьер не должен был это предотвратить? До этого отдел маркетинга мог просто обратиться к структуре данных. Теперь он снова вынужден ждать команду разработки. Очевидно, что абстрактный барьер не работает.
Признак «кода с душком»: неявный аргумент в имени функции
Команда маркетинга должна иметь возможность изменять товары в корзине для реализации своих рекламных акций, например назначить некоторым товарам бесплатную доставку или обнулить их цену. Команда разработки потрудилась и написала функции, удовлетворяющие потребностям маркетинга. Тем не менее выглядят эти функции очень похоже. Ниже приведены четыре функции, у которых действительно очень много общего:
В этом коде присутствует серьезный признак «кода с душком». Впрочем, если честно, от этих строк вообще разит. Первый и самый заметный признак — дублирование кода. Эти четыре функции почти идентичны.
Но есть и другой, более тонкий признак: главное различие между функциями — строки, определяющие поле, — также содержится в имени функции. Все выглядит так, словно имя функции (или его часть) передается в аргументе. Вот почему этот признак называется неявным аргументом в имени функции. Вместо явной передачи в аргументе значение «передается» как часть имени.
Директор по маркетингу: Код может пахнуть?
Дженна: Да, в каком-то смысле. Выражение просто означает, что в коде на что-то стоит обратить внимание. Это не значит, что код плох, но это может быть признаком существующей проблемы.
Ким: Да! Этот код определенно попахивает. Только посмотри на все это дублирование.
Дженна: Да, код действительно очень похож. Но я не вижу, как избавиться от дубликатов. Нам нужны средства для назначения цены и количества единиц товара. Разве это не разные функции?
Ким: Дублирование означает, что эти функции почти одинаковы. Единственное различие — строка с именем поля ('price', 'quantity' или 'tax').
Дженна: Да, понимаю! И эта строка также присутствует в имени функции.
Ким: Точно. И это признак «кода с душком»: вместо передачи в аргументе имя поля становится частью имени функции.
Директор по маркетингу: И вы говорите, что его можно исправить?
Ким: Да. Я знаю прием рефакторинга, который позволит заменить все четыре функции одной. Для этого нужно сделать имя поля первоклассным значением.
Директор по маркетингу: Первоклассным? В смысле первого класса — как в поезде или самолете?
Ким: Хм. Да, пожалуй. Это просто означает, что имя поля становится аргументом. Мы определим его позднее.
Рефакторинг: явное выражение неявного аргумента
Метод рефакторинга, называемый явным выражением неявного аргумента, может применяться в любой ситуации, в которой неявный аргумент является частью функции. Основная идея заключается в том, чтобы превратить неявный аргумент в явный.
Последовательность действий выглядит так:
1. Выявление неявного аргумента в имени функции.
2. Добавление явного аргумента.
3. Использование нового аргумента в теле вместо жестко фиксированного значения.
4. Обновление кода вызова.
Посмотрим, как провести рефакторинг функции setPriceByName(), которая может задать только цену, в функцию setFieldByName(), способную задать значение любого поля товара.
Применение этого рефакторинга к коду позволяет заменить четыре существующие функции одной обобщенной, — и кто знает, сколько еще функций нам не придется писать благодаря обобщенной функции setFieldByName().
Что же здесь произошло? Имя поля было преобразовано в первоклассное значение. Ранее имя поля не раскрывалось перед клиентами API, кроме как в случае неявного раскрытия как части имен функций. Теперь оно стало значением (в данном случае строкой), которое может передаваться в аргументе, но также может храниться в переменной или массиве. Именно это имеется в виду под первоклассным значением: для работы с ним может использоваться полный набор языковых средств. Преобразование к первоклассному статусу является темой этой главы.
На это можно возразить, что такое использование строк небезопасно. Эта тема будет рассмотрена на ближайших страницах, а пока просто продолжайте читать!
Загляни в словарь
Первоклассное значение может использоваться так же, как и любые другие значения в языке.
Директор по маркетингу: И нам не придется подавать заявку на изменение каждого поля?
Дженна: Вот именно. Теперь вы можете обратиться к любому нужному полю — просто укажите его имя в строковом формате и передайте его при вызове.
Директор по маркетингу: Как мы узнаем, как называется то или иное поле?
Ким: Очень просто. Мы сделаем имена частью спецификации API. Они будут частью абстрактного барьера.
Директор по маркетингу: Хмм… Идея мне начинает нравиться. Но тогда другой вопрос: а если вы добавите новое поле в спецификацию корзины или товара? Что тогда?
Дженна: Новая функция должна работать как с существующими, так и с новыми полями. Если мы добавляем новое поле, то должны будем сообщить вам его имя, и тогда вы сможете пользоваться всеми функциями, которые вам известны.
Директор по маркетингу: Звучит неплохо. Кажется, такой подход сильно облегчит нашу задачу.
Ким: Так и должно быть! В старом варианте вы должны были знать набор функций (и подавать запросы на новые функции!), а теперь достаточно знать одну функцию и набор имен полей.
Более подробно с книгой можно ознакомиться на сайте издательства.
Комментарии: 0
Пока нет комментариев