Рефакторинг или Концентрат на Завершение Приложения

23

Хотели бы вы провести рефакторинг своего приложения или сосредоточиться на его завершении? Рефакторинг будет означать, что прогресс приложения будет замедляться.

Завершение приложения будет означать, что вы получите очень сложное приложение для поддержки в дальнейшем?

Приложение представляет собой личный проект. Я действительно не знаю, как ответить «Что движет функциональностью и дизайном», но я полагаю, что это решает проблему неэффективности современного программного обеспечения. Мне также нравится минимальное простое в использовании программное обеспечение. Поэтому я удаляю некоторые функции и добавляю некоторые, которые, как мне кажется, помогут.

Jiew Meng
источник
1
Не могли бы вы предоставить некоторые дополнительные данные о вашем сценарии? Например, это проект с одним человеком или вы в команде? Это коммерческий продукт, внутренний или с открытым исходным кодом? Что движет функциональностью и дизайном?
mlschechter
@mlschechter, сейчас я работаю над личным проектом. Не определились, буду ли я продавать (например, на codecanyon) или выпущу его с открытым исходным кодом. Я действительно не знаю, как ответить «Что движет функциональностью и дизайном», но я думаю, что это решает проблему неэффективности современного программного обеспечения. Мне также нравится минимальное простое в использовании программное обеспечение. Поэтому я
удаляю

Ответы:

23

Сделай так, чтобы это работало. Тогда сделай это быстро. Наконец, сделай это красиво.

Если у вас есть хорошее разделение между вашим кодом (презентация, бизнес и уровни данных) с использованием интерфейсов, и это не монолитный дизайн, то рефакторинг не должен быть таким сложным.

Если у вас возникли большие трудности с рефакторингом, это, вероятно, кодовый запах - я предлагаю вам взглянуть на основополагающие принципы

Уотсон
источник
+1 для заставить его работать . Тогда сделай это быстро . Наконец, сделай это красиво .
Картик Сринивасан
Моя точка зрения также. Не выполняйте рефакторинг до того, как вы заставите его работать, если вы не понимаете, что ваш дизайн не позволяет вам выполнить задачу.
Гас
Если вы заставите его работать, используя модульный тест, чтобы убедиться, что он действительно работает , а не просто кажется, что он работает правильно, то структура, вызванная этими тестами, будет составлять 90% от рефакторинга, который вы когда-либо захотите сделать.
Майкл Андерсон
Я бы скорее сказал: заставь это работать, сделай это правильно, сделай это быстро - в таком порядке.
Никлас Х
Скорее, все будет так: заставь это работать , сделай это быстро , сделай это снова , сделай это красиво , сделай это снова . Если в этот момент вам нужно снова сделать это быстро, вы сделали это неправильно.
Florian F
8

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

Это соответствует духу TDD. Чтобы написать хорошие тесты, вам нужен хороший интерфейс для тестирования. Насколько грязно это за кадром в данный момент, не так важно, потому что вы можете улучшить это позже.

Joonas Pulakka
источник
5

Я всегда рефакторинг, особенно с использованием TDD.

  1. Написать тесты

  2. Сделайте тесты успешными

  3. Refactor

Это поможет вам иметь меньше ошибок и лучший код для готового продукта. Это также позволит вам иметь меньше кода для поддержки, когда вы закончите.

Джейсон
источник
5

Рефакторинг рано и часто! Время, которое вы «экономите», не делая этого, тратится много раз на попытки взломать следующую функцию и поиск ошибок в слишком сложном или хаотичном коде.

Harald
источник
2

Рефакторинг подобен поднятию вашей комнаты.

Если вы держите вещи в чистоте, у вас есть линейные накладные расходы, пропорциональные количеству продуктивной работы, которую вы делаете над кодом, O (n) с точки зрения алгоритмиста. Предполагая, что вы тратите 10% своего времени на рефакторинг (или поддержание чистоты в комнате), эти 10% являются заданными, и они будут оставаться постоянными в течение долгого времени.

Однако, если вы бросаете свою грязную одежду в угол и продолжаете делать это, количество времени, которое вы собираетесь потратить, поднимая свою комнату, увеличивается, поскольку беспорядок становится более сложным. Предполагая, что каждый отдельный кусок грязного белья экспоненциально вносит вклад в требуемое время уборки, вы находитесь в ситуации O (e n ).

Любой, кто когда-либо углублялся в концепцию алгоритмической сложности, заметит, что где-то существует точка безубыточности, то есть оптимальное количество грязного белья, которое можно накапливать; сколько это зависит от постоянных факторов, которые отбрасываются в нотации big-O. Другим фактором является ценность вашей работы с течением времени: если ваша работа стоит очень дорого сейчас, но дешево на следующей неделе (то есть, в пятницу для этого проекта есть крайний срок и еще три, но после этого вы будете в основном бездействовать). ), уравнение может оказаться в пользу не рефакторинга.

А потом есть сложность критической массы. В какой-то момент беспорядок («критический беспорядок», если хотите) становится настолько плохим, что кажется проще просто сжечь всю комнату и купить новую одежду. В действительности это обычно не так, но кажется, что так, и психологические эффекты сделают это в десять раз сложнее, чем заняться этим.

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

TL; DR: если есть сомнения, рефакторинг. У вас должны быть действительно веские доказательства, прежде чем принимать решение не делать этого.

tdammers
источник
1

Если у вас есть возможность добавлять функции или исправлять ошибки, чтобы получить удовлетворение от продаж / удовлетворения потребностей клиентов, сделайте это. Как только появилось меньше новых требований, вы можете балансировать с рефакторингом. В какой-то момент вы должны убедиться, что пишете код, который хотят люди. При прочих равных условиях я бы скорее отбросил 100 часов кода, чем 1000. Именно это вы и сделаете, если никто не захочет.

JeffO
источник
0

Действительно зависит от того, где вы находитесь!

Другие вещи, чтобы думать о:

Насколько вы уверены, что вы правильно поняли функциональный дизайн? Не могли бы вы в конечном итоге изменить дизайн после получения обратной связи с пользователем?

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

Джереми
источник
0

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

Gaurav
источник
0

Если плохой дизайн, который вы хотите реорганизовать, действительно причиняет вам боль, лучше исправить это сейчас, чем создавать больше кода, который зависит от него. Рефакторинг позже будет сложнее и дороже; скорее всего, вы больше не сможете это делать.

С другой стороны, если ваша единственная проблема - уродство, вы можете сначала завершить работу над программным обеспечением, потому что вряд ли что-то лучше, чем добиться цели .

user281377
источник
0

Рефакторинг будет очень важен, так как вы работаете над заполнением заявки.

+ VES

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

  2. Повышение производительности. Правильный рефакторинг приложения, безусловно, поможет повысить производительность приложения.

  3. Техническое обслуживание: последнее, но не менее важное, было бы легче поддерживать в долгосрочной перспективе.

-VE

  1. Отнимает много времени : это будет намного больше времени на каждом этапе вашего прогресса. Так что может быть задержка в завершении.

Нижняя граница

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

Картик Сринивасан
источник
Что такое VES и VE?
FreeAsInBeer
положительные и отрицательные.
Florian F
0

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

Завершите это и рефакторинг это. Но если нет крайних сроков, чтобы спешить или сроки, я предлагаю рефакторинг, это было бы хорошо.

user962206
источник