> но проще ведь пупо проверить, не? в цикле?Вот кстати да. Сделал вот такую штуку:
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 просто остается в максимальном значении. Это оптимизация так работает?