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

Как бы вы отнеслись к такой конструкции мини-цепочек обязанностей?


Или есть более красивые способы это реализовать? Просто в фильтрах несколько десятков if-else и как-то логически хочется их организовать... Ессно реальные имена не содержат 1,2,3, а названы понятно.

type Constructor struct {
finished bool
result Result // любой нужный тип
}


func NewConstructor() Constructor { // метод для читабельности
return Constructor{finished: false}
}

func (c Constructor) RunChain1(needs parametrs...) Result {
complete := c.filter1(part parametrs).
filter2(part parametrs).
filter3()

if !complete.finished {
return Default()
}

return complete.result
}

func (c Constructor) filter1(part parametrs) Constructor {
if c.finished {
return c
}

... handler logic...
может поставить c.finished = true и вернуть с результатом или вернуть без результата
}

...
// может быть несколько RunChain и много filter

5 ответов

6 просмотров

NewConstructor - звучит страшно. Конструктор для объекта Constructor... А в целом - да вроде неплохо. В чем смысл нескольких RunChain?

Борис-Пол Автор вопроса
Mikhail Efimov
NewConstructor - звучит страшно. Конструктор для о...

В другом месте понадобится немного изменённая цепочка, без одного фильтра.

Борис Пол
В другом месте понадобится немного изменённая цепо...

А нужны вообще все эти объекты, цепочки? Много разных типов объектов планируется фильтровать? Если только один, то и абстракции на эту тему можно не делать

Борис-Пол Автор вопроса
Mikhail Efimov
А нужны вообще все эти объекты, цепочки? Много раз...

))) Это не вполном смысле цепочка обязанностей)) Там нет интерфейсов и абстракций) Просто способ из нескольких десятков if-else сделать читабельную логику

Борис Пол
))) Это не вполном смысле цепочка обязанностей)) Т...

Ок. Иметь именованные фильтры, каждый из которых включает в себя несколько условий на одну тему - норм способ организации, как по мне

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

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

Скажите, можно ли как-то "переместить" динамический массив из одной переменной в другую? Скажем, переместить из TList<> в TArray<>. Именно переместить, а не скопировать. Если ...
Eugene Krasnikov (ᴊɪɴ x)
37
комрады, че-та лыжы не едут var tmpFont: TFont; begin tmpFont:= TFont.Create; try case rgFontColor.ItemIndex of 0: tmpFont.Color:= clWindowText; 1: tmpFo...
Ed Doc
34
.model small .stack 100h .data a db 'Hello, World!', '$' ; исходная строка b db 20 dup(?) ; строка b с запасом на максимальную длину .code main: ...
Алексей -man
3
М-да. Почему бы просто со stringlist не работать?
Michael Longneck
23
Редактор листа Excel, по сути двумерный массив ячеек. Ячейка - это экземпляр класса, у нее всякие свойства, методы. Проблема в том, что количество используемых строк и колоно...
Sergey Bodrov
2
Интересно, нет ли какого-то способа получить из dll не адрес самой метки, а адрес со смещением?
The Bird of Hermes
54
Is there a digital way to cut the electricity from a usb in linux? It sounds weird, but it's exactly what I need to do. I tried to simulate the unplug/replug but is not the ...
Eduard Rivas
15
Добавляю 100 тыс слов в TListBox. Перемешаю скролл (от ListBox). После примерно 65536 скролл резко прыгает вверх. Это что за глюк? Как фиксить, кто-нибудь знает?
Eugene Krasnikov (ᴊɪɴ x)
8
generic procedure function test<T>(param: T); type case T of longint: NewT = word; longword: NewT = byte; end; var v1: NewT; Как это можно сделать? Чтобы у меня...
notme
21
Делал задачу вот такую https://stepik.org/lesson/4985/step/9?unit=1083 получилось такое https://play.haskell.org/saved/ipKrepqe оно работает, тестов много не писал, но работае...
Fedor
22
Карта сайта