169 похожих чатов

Как лучше? (все именования для примера) Имеется билдер вида Builder::main1(first: 'x', second:

'y')->a()->b()->build(): C, создаёт инстанс класса C с некоторыми свойствами. Встала необходимость добавить в C ещё одно обязательное свойство, например, foo.

Варианты:
— Builder::main1(first: 'x', second: 'y', fooValue: 'abc')->a()->b()->build()

— Builder::main1(first: 'x', second: 'y')->a()->b()->withFoo('abc')->build()

Кроме main1() есть ещё три аналогичных метода-конструктора (но аргументы разные), всем придётся добавить ещё один аргумент и отрефакторить вызовы (в гитлоге, да и вообще, правка строки выглядит и читается хуже, чем добавление/удаление строки).

Вроде, уже два минуса есть и второй вариант выигрывает?

22 ответов

37 просмотров

Визуально второй красивее, но если первый вариант явно упадёт без нового аргумента, то второй спокойно будет работать и его хер отдебажишь и найдёшь проблему) Я всегда за явное падение кода в нестандартный ситуации

ну он же обязательный!

Артём- Автор вопроса
E V.
Визуально второй красивее, но если первый вариант ...

Второй работать не будет, потому как результат не сбилдится, аргумент-то обязательный

Артём- Автор вопроса
Adel
ну он же обязательный!

Первый вариант строже, факт. Считать это более приоритетным?

Артём
Второй работать не будет, потому как результат не ...

Ну ->b() же будет отдавать какой то экземпляр

Артём- Автор вопроса
Adel
сбилдится) но не выполнится

Нет, упадёт, когда в конструктор C придёт нулл вместо значения для этого аргумента

Артём
Нет, упадёт, когда в конструктор C придёт нулл вме...

да я понятиями компилируемого языка говорю)

Артём
Билдер

Вот ) то есть до этого этапа код дойдёт) и если я на этом прекращу, то у меня будет какой то билжер болтаться в коде ошибочный с самого начала )) Вообщем я за первый варик ))

Артём- Автор вопроса
Adel
да я понятиями компилируемого языка говорю)

А я думал чем отличается компилируемый от интерпретируемого)) Неплохой пример )

Артём
Ничего болтаться не будет

Ну а кто мне запретит создать такой экземпляр билдера? Я же не знаю когда создаю объект что ещё 1 обязательный метод нужно применить ) и ваще не знаю обязательный он или нет ))

Артём- Автор вопроса

и вообще. что ты не как ларавельщик. где модели и контроллеры? Нафиг тебе эти билдеры!?

E V.
А что плохого в таких билдерах?

они не благословлены Тейлором!

Артём- Автор вопроса
Adel
и вообще. что ты не как ларавельщик. где модели и ...

Душа-то просит — займи и выпе.. ой, не то

Adel
они не благословлены Тейлором!

Я только увидел что статический метод не замокать в тестах

Похожие вопросы

Обсуждают сегодня

#include <stdio.h> #include <stdlib.h> #include <time.h> void mass_first_generate(int mass[5][7]) {     for (int N = 0; N < 5; N++) {         for (int A = 0; A < 7; A++) {   ...
Чувак
6
Всем привет! Имеется функция: function IsValidChar(ch: UTF8Char): Boolean; var i: Integer; ValidChars: AnsiString; begin ValidChars := 'abcdefghijklmnopqrstuvwxyzABCDE...
Евгений
44
Всем привет! Решаю 99 OCaml Problems и столкнулся со следующей проблемой (прошу палками не забивать, я OCaml практически не трогал до этого момента): open OUnit2 let create_...
К|/|pи/\/\ 6е3yглbIи
2
https://www.linkedin.com/posts/ugama-benedicta-kelechi-codergirl-103041300_mobiledevelopment-fluttertraining-handsonlearning-activity-7263445699227254784-IdHB?utm_source=share...
CoderGirl
16
возможно ли как-то передать в электрон или таури медиа поток с рендера 2д движка? двиг запускается как dll, а дальше надо как-то отправлять рендер кодировать не подходит, зр...
Kyle Nekto
7
Ну вот просто даже давайте вот как. Какой нибудь конкретный кейс, можете в пример привести, где бч работает и приносит прикладную пользу, а не просто что бы было? Не крипту.
Alexander Andreev
22
Помогите пожалуйста. Делаю систему плагинов. Проблема сейчас в такая: плагины загружаются в основном потоке. FLibHandle := SafeLoadLibrary(FFileName) Но нужно еще выполнить фу...
Илья 🤣
10
объясните пожалуйста, почему функция не работает должным образом? вроде должно брать активное окно сравнивать его размер с размером экрана, и если есть совпадение = true прове...
JF
12
лучше скажите, причём тут паскаль?
Alexey Kulakov
36
Но, может, есть уже проверенная? Наши требования такие: 1. Сообщения должны приходить из Инста в CRM оду 2. Должна быть возможность подключить несколько экаунтов Инстаграм. Р...
Alexander Sharoiko MSE / Александр Шаройко
13
Карта сайта