The OpenNET Project / Index page

[ новости /+++ | форум | теги | ]



"Рекурсивное использование asprintf"
Версия для распечатки Пред. тема | След. тема
Форум Программирование под UNIX
Исходное сообщение [ Отслеживать ]

. "Рекурсивное использование asprintf" +/
Сообщение от datswdemail (?), 03-Окт-20, 08:07 
> но проще ведь пупо проверить, не? в цикле?

Вот кстати да. Сделал вот такую штуку:

    int i = 1;
    char *p = NULL;
    char *c = "lalafalkjsdfhklj3h2iuhnklfsajbnlfiu2b    lkjdbslkabfqwilubfkldsajbfkljewqlkfdsa";
    int l = (int)strlen(c);
    while (1) {
//        p = realloc(p, i * (l + 1) * sizeof(char));
//        sprintf(p, "%s%s", i > 1 ? p :"", c);
        asprintf(&p, "%s%s", i > 1 ? p :"", c);


        i++;
        if(i >= 100000) {
            printf("Free memory\n");
            free(p);
            p = NULL;
            printf("Goto sleep\n");
            sleep(5);
            i = 1;
            printf("Go on\n");
        }
    }

Очень скоро после запуска оно сжирает всю память и ps -ax начинает говорить, что не может выполниться потому что нет памяти :))

Если заменить asprintf на realloc + sprintf, то он вполне себе нормально работает.

Ещё обратил внимание на то, что после первой итерации он память чистит, и pmap показывает, что в heap свободно, после всех последующих heap просто остается в максимальном значении. Это оптимизация так работает?

Ответить | Правка | Наверх | Cообщить модератору

Оглавление
Рекурсивное использование asprintf, datswd, 27-Сен-20, 09:14  [смотреть все]
Форумы | Темы | Пред. тема | След. тема



Партнёры:
PostgresPro
Inferno Solutions
Hosting by Hoster.ru
Хостинг:

Закладки на сайте
Проследить за страницей
Created 1996-2024 by Maxim Chirkov
Добавить, Поддержать, Вебмастеру