о функциях (программистское)

топ 100 блогов avva05.01.2010 Эта запись будет интересна только программистам.

Предлагаю вопрос о том, как обустраивать код. Представьте себе, что у вас есть функция foo() (неважно, на каком языке; может, это метод, а не функция - неважно), вся работа которой - вызвать какие-то другие четыре функции A(), B(), C(), D(), которые расположены в других файлах и которые и делают всю основную работу. foo() должна приготовить для них аргументы, передать результаты работы A() в B(), и так далее. Логика foo() выглядит очень просто:

1. Вызвать A().
2. Вызвать B().
3. Вызвать C().
4. Если результат, который вернула C, интересный (условие на одну строчку), вызвать D().

Каждый из этих пунктов занимает где-то 5-10 строк: кроме самого вызова, из-за того, что он готовит правильные аргументы, проверяет, что функция вернула, плюс комментарий, плюс в нескольких местах пишет что-то в лог - в общем, всякие мелочи, но накапливается. Общий размер функции foo() - 40 строк.

Есыь предложение разбить функцию foo(), выделив каждый из логических кусков в отдельную функцию - скажем, doA(), doB() итд. - чтобы foo() только их вызывала. Противник этого преедложения говорит, что на данный момент нет никаких оснований считать, что кому-то еще понадобиться вызывать doA(), doB() итд., кроме foo(). Кроме того, тестировать отдельно doA(), doB() итд. тоже не надо - у главных функций A(), B() итд. есть свои тесты, и у foo() будет свой тест. С другой стороны, сторонник этого предложения, соглашаясь с этим, говорит, что все равно foo() слишком длинна, и что раз есть возможность выделить ее части в отдельные функции, правильным будет сделать этот рефакторинг. После него код будет читабельнее, понятнее, и удобнее для поддержки.

Как вы считаете? И какие аргументы выдвинули бы в поддержку своей точки зрения?

Оставить комментарий

Архив записей в блогах:
Вслед за отбомбившимися британскими ВВС , с 1 декабря бундесвер поддерживает Францию и международный альянс против ИГ. Для этого посылает фрегат на поддержку "Шарля де Голля" , а так же обслугу - в общей сложности до 1200 солдат, и готовит Panavia Tornado (далее "Торнад ...
Карамель с помадной начинкой к чаю Минералка, сыр голландский и ацидобифилин Сыр к утреннему кофе, а напитки когда угодно пить ...
Может кто помнит про сей гаджет? https://kotenka-m.livejournal.com/1125723.html Сейчас сняла показания со счетчика - 148 кВт за месяц. При том, что неделю он работал почти не выключаясь, но на самой минималке, ибо ее было достаточно для комфортного пребывания. Кондиционер при меньшей ...
На 1 месте в ТОП ЖЖ – благородная статья про быдло . Почему-то не удивительно, правда? На сей раз признаком «быдловости» стал вопрос: напечатают ли «Шарли Эбдо» что-нибудь «весёленькое» про теракты в Париже? И автор со всей пытливостью своего ума задаётся этим вопросом. Приход ...
Обед в швейцарском городе N. 9 января 2020 года двое работяг сели пообедать в небольшом тихом ресторанчике на углу Центральной и Индустриальной, в 350 метрах от бушующей стихии. Заказали по говяжьему гамбургеру и по коле, стали ждать. Столик им достался лучший — у единственного ...