Версия для печати темы
Нажмите сюда для просмотра этой темы в оригинальном формате
Форум программистов > C/C++: Общие вопросы > Деструктор строк


Автор: Gwendolen 30.10.2006, 06:48
Вопрос таков:
Будет ли уничтожена строка CHAR*, ( LPTSTR), а также CHAR chBuffer[buffLen] при выходе ее из зоны видимости?
Для работы со строками использую только WinAPI: lstrcpyn, lstrcat и т.д. 
Есть ли необходимость в деструкторе строк для предотвращения утечки памяти smile 
Код

HeapFree (GetProcessHeap(), 0, Str);
 

Автор: witeman 30.10.2006, 08:42
Смотря куда указывает char* - если указатель ссылается на  динамическую строку, 
а значит при выходе из области в которой ты его объявил, ты не сможешь к нему обратиться,
но при этом память выеленная с помощь new, будет по-прежнему "зарезервированна".

Автор: Earnest 30.10.2006, 09:13
Цитата(Gwendolen @  30.10.2006,  07:48 Найти цитируемый пост)
Будет ли уничтожена строка CHAR*, ( LPTSTR), а также CHAR chBuffer[buffLen] при выходе ее из зоны видимости?


char buffer[bufflen] - да - это (скорее всего) автоматическая переменная.
char* - в общем случае нет.
Смотря как инициализируется char*: если char* pstr = new char[buflen], то ты обязан явно вызывать деструктор (delete), если char* pstr = "любая строка", то никакой утечки памяти не будет - это просто указатель на статическую память (скоре всего, но может быть и на автоматическую. В любом случае, не твоя забота.)
HeapFree нужно (и можно!) вызывать только для указателя, который получен через HeapAlloc, иначе порушишь heap.

Автор: Gwendolen 30.10.2006, 10:15
Выделение памяти на совести WinAPI.
Написал тестовое приложение:
Код

#include <iostream>
#include <windows.h>

void CycleFunc (LPCTSTR input_str)
{
    CHAR* str1;
    lstrcpyn(str1, input_str, lstrlen(input_str)+1);
    std::cout<< "str1 = " << str1<<std::endl;
    CHAR* str2;
    lstrcpyn(str2, "str_2", 5+1);
    lstrcat(str2, input_str);
    std::cout<< "str2 = " << str2<<std::endl;
}

int main() 
{
    char bufRus[256];
    CharToOem("Введите продолжительность цикла: ",bufRus);
    
    int CycleLen  ;
    std::cout << bufRus;
    std::cin>>CycleLen;
    std::cout<<"CycleLen = " << CycleLen<<std::endl;
    while (CycleLen > 0)
    {    
        for (int i=0; i <= CycleLen; i++)
            CycleFunc ("WERY LONG STRING: idofd fdfjklu wepre fjlekf sdfl;dk fsdfkld;j fsdjlkf sdjlfdk flsdfj sdl;fkd flsdf sdlfjsdj fdjklsf dsjlfusdfdoif sdiiofdsfhsd fhds;fldhf dlfhdfldh flsdjkfhdf sdhfkd hfhkdkfhkdfsdkfdhfhdfdfhdfhidofh dfhdfh iodf dyifosdfdhiofhsdfhisdhofisdfhio sdhiof df sdhiofh d fiosd fdhifodhiofdfhdofhdsfisdopfihdfopdhifidsh;afsdhif;asdhifsdaf;hdfsdfiiosdaifsdioafisdi;fhidhifdifidhifsdhifhi;dshifihsdhifhi;hifdhifhisdfhiodshifhi diohfh dhio;saf dahi; ");
        std::cout <<"END i = "<<CycleLen<<"CYCLE \n"<<std::endl;
   
        CharToOem("Введите продолжительность цикла: ", bufRus);
        std::cout << bufRus;
        std::cin >> CycleLen;
        std::cout<<"CycleLen = " << CycleLen<<std::endl;
    }

    return 0;
}

Погонял 80000 циклов,  диспетчер задач приращения памяти не показал. 

Автор: Daevaorn 30.10.2006, 10:20
Gwendolen, Ну ты даешь!
Цитата(Gwendolen @  30.10.2006,  11:15 Найти цитируемый пост)
CHAR* str1;
    lstrcpyn(str1, input_str, lstrlen(input_str)+1);

У тебя сегодня счастливый день. BSOD тебя пожалелsmile

Добавлено @ 10:22 
Кто память то выделать будет за тебе? Пушкин?smile

Автор: Earnest 30.10.2006, 12:11
Цитата(Daevaorn @  30.10.2006,  11:20 Найти цитируемый пост)
У тебя сегодня счастливый день

Наоборот, ему жутко не повезло. Представь себе, что это часть большого проекта, и до одного прекрасного момента все вроде работает. А потом изменяется какой-то дальний кусок кода, а про этот он уже и думать забыл...

Функции strcpy просто пишут байты по указанному адресу, и им абсолютно по барабану, что там было до того... 

Автор: Gwendolen 30.10.2006, 22:08
   Понял, вопрос решен - буду выделять память, а потом освобождать. Тогда и утечек не будет smile 
   А теперь внесу изменения в разрабатываемый мною проект...

Автор: SaDFromSpb 1.11.2006, 12:59
Gwendolen, Вообще для таких тестов неплохо еще и библиотечку efence подключать. - Она следит за корректностью работы с памятью. В случае с lstrcpyn отвалилось бы сразу.
P.S. Хотя пользуюсь ей только под никсами и даже не знаю, есть ли у нее версия под винды (что-то аналогичное по-любому должно быть). Если что - попинайте.

Powered by Invision Power Board (http://www.invisionboard.com)
© Invision Power Services (http://www.invisionpower.com)