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

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

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

24 ответов

17 просмотров

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 писать =))

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

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

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

а через ESC-код ?
Alexey Kulakov
29
30500 за редактор? )
Владимир
47
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
13
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
program test; {$mode delphi} procedure proc(v: int32); overload; begin end; procedure proc(v: int64); overload; begin end; var x: uint64; begin proc(x); end. Уж не знаю...
notme
6
Как передать управляющий символ в открытую через CreateProcess консоль? Собсна, есть процедура: procedure TRedirectThread.WriteData(Data: OEMString); var Written: Cardinal;...
Serjone
6
вы делали что-то подобное и как? может есть либы готовые? увидел картинку нокода, где всё линиями соединено и стало интересно попробовать то же в ddl на lua сделать. решил с ч...
Victor
8
Ребят в СИ можно реализовать ООП?
Николай
33
Подскажите пожалуйста, как в CustomDrawCell(Sender: TcxCustomGridTableView; ACanvas: TcxCanvas; AViewInfo: TcxGridTableDataCellViewInfo; var ADone: Boolean); получить наз...
A Z
7
Карта сайта