this can work:
const int size = 2;
int array[size] = {0};
this has compile error:
int a = 2;
const int size = a;
int array[size] = {0};
why?
Because the guys in the C++ committee decided so.
The technical reason is that the first expression that is used to initialize size
is a constant expression and it can be computed during compilation. This means that the compiler can also know how big the array is going to be and the allocation (in this case "reservation" may be a more appropriate term) can be done at compile time.
In the second case instead the expression is not a constant expression (given the C++ definition) and this revervation is not possible.
The fact that in the second case the value is indeed fixed by the time size
is initialized is totally irrelevant. The rules are base on the "kind of expression" and the second expression uses mutable variables and thus the compiler considers it non-constant.
Allowing the second form for compile-time initialization would require a flow analysis because the compiler would need to distinguish between
int a = 2;
const int size = a;
and
int a = foo();
const int size = a;
where the expression involving size
is indeed identical.