того что почитал, это встроенная в gcc защита от дебила, когда буффер переполняется. Почему, чисто в теории, так происходит - понятно, я рекурсивно прохожусь по всех директориях системы. Но, как это правильно исправить? Тут больше вопрос по тому как оно устроено внутри. Если у меня 5 раз рекурсивно вызвалась функция, например, она забирала себе участок памяти каждый раз. Но, например, если отработали 4 из 5 этих функций, я себе представляю, что место, с этих 4х функций, при возврате вернулось в пользование. Это так? Или сначала рекурсивная функция (или даже программа в целом) должна отработать полностью и завершиться, дабы память вернулась?
Показывай код. Пять раз вызванная рекурсивно функция не переполнит стек, если там нет жирнющих локальных переменных. Насчёт возврата памяти - всё так, память "возвращается" в момент завершения выполнения функции
Это я для примера. Сейчас с компа кину. Скорее всего переменные там достаточно занимают, дабы положить буффер.
В main`e начинается поиск с дир /home. Можно поменять. А ломается примерно на 14й директории внутрь.
Это не stack overflow, а buffer overflow - скорее всего, на имя директории не хватает 255 символов
‘nextdir’ accessing 1000 bytes in a region of size 255 [-Wstringop-overflow=] Варнинг получаю. Вроде как я не могу больше 255 передать внутрь
char filename[256]; char seachFile[256];
я везде заменил на 1000
полный пример кода
Обсуждают сегодня