在C语言中,我们可以使用malloc、calloc和realloc函数来动态分配内存。这些函数都位于stdlib.h头文件中,因此在使用它们之前,请确保包含了该头文件。
#include <stdlib.h>
int main() {
int *ptr;
int n = 5;
ptr = (int*) malloc(n * sizeof(int));
if (ptr == NULL) {
printf("Memory allocation failed.\n");
return 1;
}
// 使用分配的内存
// ...
// 释放内存
free(ptr);
return 0;
}
#include <stdlib.h>
int main() {
int *ptr;
int n = 5;
ptr = (int*) calloc(n, sizeof(int));
if (ptr == NULL) {
printf("Memory allocation failed.\n");
return 1;
}
// 使用分配的内存
// ...
// 释放内存
free(ptr);
return 0;
}
#include <stdlib.h>
int main() {
int *ptr;
int n = 5;
ptr = (int*) malloc(n * sizeof(int));
if (ptr == NULL) {
printf("Memory allocation failed.\n");
return 1;
}
// 使用分配的内存
// ...
// 调整内存大小
int new_n = 10;
ptr = (int*) realloc(ptr, new_n * sizeof(int));
if (ptr == NULL) {
printf("Memory reallocation failed.\n");
return 1;
}
// 使用调整后的内存
// ...
// 释放内存
free(ptr);
return 0;
}
在C语言中,我们可以使用malloc、calloc和realloc函数来动态分配内存。这些函数都位于stdlib.h头文件中,因此在使用它们之前,请确保包含了该头文件。
malloc函数用于分配指定字节数的内存。它返回一个指向分配内存的指针,如果内存分配失败,则返回NULL。calloc函数用于分配指定数量的指定大小的内存,并将其初始化为0。它返回一个指向分配内存的指针,如果内存分配失败,则返回NULL。realloc函数用于调整之前分配的内存大小。它需要一个指向之前分配的内存的指针和新的内存大小。如果调整成功,它返回一个指向新内存的指针,如果内存分配失败,则返回NULL。
在使用完动态分配的内存后,务必使用free函数释放内存,以避免内存泄漏。以下是使用这些函数的示例代码:
#include <stdlib.h>
int main() {
int *ptr;
int n = 5;
ptr = (int*) malloc(n * sizeof(int));
if (ptr == NULL) {
printf("Memory allocation failed.\n");
return 1;
}
// 使用分配的内存
// ...
// 释放内存
free(ptr);
return 0;
}
#include <stdlib.h>
int main() {
int *ptr;
int n = 5;
ptr = (int*) calloc(n, sizeof(int));
if (ptr == NULL) {
printf("Memory allocation failed.\n");
return 1;
}
// 使用分配的内存
// ...
// 释放内存
free(ptr);
return 0;
}
#include <stdlib.h>
int main() {
int *ptr;
int n = 5;
ptr = (int*) malloc(n * sizeof(int));
if (ptr == NULL) {
printf("Memory allocation failed.\n");
return 1;
}
// 使用分配的内存
// ...
// 调整内存大小
int new_n = 10;
ptr = (int*) realloc(ptr, new_n * sizeof(int));
if (ptr == NULL) {
printf("Memory reallocation failed.\n");
return 1;
}
// 使用调整后的内存
// ...
// 释放内存
free(ptr);
return 0;
}
‧‧‧‧‧‧‧‧‧‧‧‧‧‧‧‧ END ‧‧‧‧‧‧‧‧‧‧‧‧‧‧‧‧