Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2003.02.06;
Скачать: CL | DM;

Вниз

Поиск утечек памяти по исходнику *.PAS   Найти похожие ветки 

 
Stager   (2003-01-27 00:31) [0]

Интересна информация про сабж. Но с некоторыми деталями. Мне известно про существование BoundsChecker"а и прочих утилит, работающих с исполняемым файлом. Они работают "пост фактум", то есть по завершении программы смотрят, какая память освободилась, а какая нет. А нет ли средств, способных отследить возможность утечки памяти по исходнику? Например, компилятор Дельфи еще до запуска умеет выдавать хинты вида: "Variable X might not have been initialized", исходя из анализа текста PAS-файла. А есть ли софт, предназначенный для анализа исходника на предмет memory leaks? Что скажете, Мастера?

ЗЫ. По глупости сначала запостил эту тему в "Просто потрепаться". Надеюсь, не прибьют заживо...

С уважением, Алексей.


 
cypher   (2003-01-27 01:46) [1]

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


 
Stager   (2003-01-27 16:04) [2]

2 cypher

Ну вот предположим... Написал я тут один компонент, и на суд всеобщий выставил. Мне сразу говорят: см. там-то и там-то, утечка памяти, объект создается и не удаляется. Хорошо. А ту же самую логику, которой руководствовались при этом уважаемые критики, в программный код впихнуть? Разве это до сих пор никто не сделал?

С уважением, Алексей.


 
Кот Бегемот   (2003-01-27 17:13) [3]

2Stager © (27.01.03 16:04)
Спасибо за комплимент конечно :)))
Это не логика - Это интуиция :)))


 
cypher   (2003-01-28 01:29) [4]

Stager, наверное дело в том, что в твоей компоненте не так много заковырок для анализа, и ошибка очевидна... но универсальный алгоритм придумать очень не просто, поэтому его и борланд (да и все остальные) не морочаться по этому поводу... реализовали для таких вещей уже давным давно Garbage Collector (так пишется?) по рабоче-крестьянски - сборшик мусора, который сам удаляет потерянную память...
и вообще, соблюдение банальных правил написания "хорошего" -кода, имхо самый удачный вариант избавления от таких ошибок



Страницы: 1 вся ветка

Текущий архив: 2003.02.06;
Скачать: CL | DM;

Наверх




Память: 0.45 MB
Время: 0.01 c
3-15476
Serginio
2003-01-20 15:51
2003.02.06
1C на Delphi


14-15886
McSimm
2003-01-19 15:39
2003.02.06
Будьте осторожны


3-15494
satron
2003-01-20 14:08
2003.02.06
Как не дать


1-15668
Step[B.M.]
2003-01-29 18:05
2003.02.06
Группа компонентов в одном имени


1-15564
Anbezr
2003-01-28 16:25
2003.02.06
Переопределение констант





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский