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

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

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

24 ответов

5 просмотров

https://t.me/advice17/7

Нет. Как минимум для тестирования лучше все функции делать глобальными

Tishka17
https://t.me/advice17/7

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

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

перечитай что там написано, ну и ты должен НАЙТИ ПРИЧИНУ ЭТО СДЕЛАТЬ, а не наоборот

И друг мой грузовик 🚛
да

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

И друг мой грузовик 🚛
да

Недостатки вложенных функций: * Они создаются при каждом запуске внешней функции * Их невозможно протестировать * Увеличивают вложенность кода, что усложняет чтение

внутри той же первой функции считай суммы элементов, либо же просто создай ещё одну функцию в которую отправишь список, и она вернёт суммы элементов

Tishka17
Недостатки вложенных функций: * Они создаются при ...

1. она будет вызываться всегда когда будет вызвана основная функция, сама по себе она бесполезна 2. Там тестировать нечего, туда попадают уже чистые данные. 3. Там функция без её определения одна строчка, куда там заблудиться можно

И друг мой грузовик 🚛
1. она будет вызываться всегда когда будет вызвана...

1. и? это не повод пересоздавать её 2. если нечего тестировать, функцию можно удалять вместе с кодом. 3. тогда непонятно зачем функция

Tishka17
1. и? это не повод пересоздавать её 2. если нечего...

ну может быть ты и прав, и стоит просто выпилить её

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

стоит её не выпилить, а переместить в глобальный скоуп

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

да вынеси ты её наружу, дай нормальное имя. БУдет лежать никому не мешать

И друг мой грузовик 🚛
1. она будет вызываться всегда когда будет вызвана...

Это может выглядеть прикольно с точки зрения организации кода (типа, всё связанное лежит рядом и не мешает остальному), но это так себе аргумент и плюсы на этом заканчиваются.

Tishka17
да вынеси ты её наружу, дай нормальное имя. БУдет ...

Тут, кстати, есть момент. При рефакторинге можно очень легко пропустить такие одноразовые штуки. Если внешняя функция станет не нужна и её удалят, совсем не факт, что эту служебную заметят и увидят, что она использовалась только в одном месте. В результате в проекте годами могут жить призраки, которые нигде не нужны, но удалить никто не решается.

хм, разумно. Возможно тут бы помог __all__ и линтер

Tishka17
хм, разумно. Возможно тут бы помог __all__ и линте...

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

Tishka17
да вынеси ты её наружу, дай нормальное имя. БУдет ...

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

evle
Чем? Просто я на нескольких долгоживущих проектах ...

ну такую внутреннуюю функцию не добавляешь в all и настраиваешь линтер ругаться на неиспользуемые функции

Tishka17
ну такую внутреннуюю функцию не добавляешь в all и...

Интересный вариант, надо подумать, чем это грозит.

Tishka17
тем что придется везде all писать =))

Это да. уже малость неприятно. Подозреваю, что ещё проблемы могут вылезти с какими-нибудь ложными срабатываниями.

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

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

а зачем этот вопрос для удаления из чата?
Mёdkinson Medvezhkin
63
Добрый день. Хочу сделать отрисовку по команде на панели. Почему-то рисуется только при втором вызове. С чем может быть связано, не подскажете? procedure TForm1.FormDblClick(...
Kirill Filippenok
20
Всем доброго дня! Подскажите может кто использовал связку Pagebuilder + Clientsetting. Сами параметры с типом pagebuilder в модуле Clientsetting работают нормально, можно такж...
Александр Добриков
12
А почему в си некоторые вещи работают с двойными кавычками некоторые с одинарными? Нельзя было все сделать с одними или чтоб работало с разными? например чтоб выводить строки ...
.
15
Всем привет! Нужен совет от опытных. Переношу свой проект с Делфи 10.2 Токио на Лазарус 3.2 установленный через инсталлятор fpcupdeluxe-x86_64-win64. При импортировании проект...
Дмитрий Завгородний
7
Эх кто-то пришел и весь праздник испортил :( You need complex FBX scene importing setup to change things on import? good luck with that. You need navigation and pathfinding? g...
Serg Gini
5
Всем привет! procedure TForm1.FormCreate(Sender: TObject); type TStartEnd = record S: Byte; E: Byte; end; var a, b: TStartEnd; begin {1} a.S := 1; {2} a.E := 2; ...
Руслан Михайлович
10
Всем привет!) я тут новенький и пытаюсь освоить evolution методом тыка. У меня при переходе между папками файлов выскакивают вот такие уведомления Можете подсказать как их от...
Диман Samoed
10
Всем привет! Подскажите. Я написал приложение на Delphi 10.2 Tokyo под Windows 10. И передо мной стал вопрос о том чтобы сделать это приложение кроссплатформенным (под Linux и...
Дмитрий Завгородний
24
Какого хера? /Sources/App/Modules/User/Models/UserLinkApple.swift:21:20: warning: stored property '_id' of 'Sendable'-conforming class 'UserLinkApple' is mutable @ID(...
Alexander Sherbakov
14
Карта сайта