Проблема в порядке операций: n + 1 * sizeof(int)
означает «умножить в 1 раз размер (int), затем добавить n».Вы можете использовать скобки для обеспечения порядка: (n + 1) * sizeof(int)
.
Выделение памяти может быть дорогим!Попросите разумный кусок памяти, затем увеличивайте его так часто, скажем, в два раза. При системном вызове выделения памяти ОС может дать вам блок большего размера, чем вы просили, чтобы последующие вызовы realloc
менее дорогой и использует память, уже доступную вашей программе.
Хорошо проверить, что ваши вызовы malloc
и realloc
выполнены успешно.Эти функции возвращают NULL, если запрос на выделение завершился неудачей.
Кроме того, не забывайте free
выделенную память, когда вы закончите с ней, чтобы избежать утечек памяти.
Это может быть веселоупражнение для написания собственного интерфейса, подобного «vector / ArrayList / list», который расширяется и сжимается до размера и, возможно, содержит такие операции, как slice(start_index, end_index)
и remove(index)
.
. Вот полный пример:
#include <stdio.h>
#include <stdlib.h>
int main() {
int nums_len = 0;
int nums_capacity = 5;
int *nums = malloc(nums_capacity * sizeof(int));
while (scanf("%d", &nums[nums_len]) != -1) {
if (++nums_len >= nums_capacity) {
printf("increasing capacity from %d to %d\n",
nums_capacity, nums_capacity * 2);
nums_capacity *= 2;
nums = realloc(nums, nums_capacity * sizeof(int));
if (!nums) {
fprintf(stderr, "%s: %d: realloc failed\n",
__func__, __LINE__);
exit(1);
}
}
printf("got: %d\n", nums[nums_len-1]);
}
printf("Here are all of the %d numbers you gave me:\n", nums_len);
for (int i = 0; i < nums_len; i++) {
printf("%d ", nums[i]);
}
puts("");
free(nums);
return 0;
}
Пример прогона:
5
got: 5
6
got: 6
7
got: 7
8
got: 8
1
increasing capacity from 5 to 10
got: 1
3
got: 3
5
got: 5
6
got: 6
7
got: 7
1
increasing capacity from 10 to 20
got: 1
2
got: 2
3
got: 3
4
got: 4
5
got: 5
6
got: 6
67
got: 67
8
got: 8
1
got: 1
2
got: 2
3
increasing capacity from 20 to 40
got: 3
4
got: 4
1
got: 1
2
got: 2
Here are all of the 23 numbers you gave me:
5 6 7 8 1 3 5 6 7 1 2 3 4 5 6 67 8 1 2 3 4 1 2