我研究了很多静态和动态内存分配,但仍有一个混乱:
int n, i, j;
printf("Please enter the number of elements you want to enter:\t");
scanf("%d", &n);
int a[n];
for (i = 0; i < n; i++)
{
printf("a[%d] : ", i + 1);
scanf("%d", &a[i]);
}
int a[n]
是否受静态或动态内存分配?
不,这是自动分配
C标准没有讨论动态分配(或静态分配)。但它确实定义了存储持续时间:静态,自动,线程和分配。这决定了一个对象(一块数据)存在多久(可用)。
static
的局部变量具有静态存储持续时间。for
循环的花括号内)。malloc
和朋友获得的记忆。它可以从(成功)调用malloc
获得,直到相应的调用free
。这通常被称为动态内存分配,因为它是一种获取具有在运行时确定的大小的内存块的方法。您的变量a
具有自动存储持续时间。但是,它可以被认为是动态的,因为它的长度是在运行时确定的,而不是在编译时确定的。就像分配的存储持续时间一样。
int a[n]
是一个具有自动存储持续时间的可变长度数组,
考虑以下示范程序。
#include <stdio.h>
#include <string.h>
int main(void)
{
const size_t N = 10;
for ( size_t i = 1; i <= N; i++ )
{
char s[i];
memset( s, '*', sizeof( s ) );
printf( "%*.*s\n", ( int )i, ( int )i, s );
}
return 0;
}
它的输出是
*
**
***
****
*****
******
*******
********
*********
**********
每次将控件传递给循环体时,编译器代码生成的本地数组s[n]
的生命周期结束于循环体的末尾。