If there is a pair of .h/.cpp files with something like, respectively,
extern const float ge;
and
const float ge = 2.2f;
in them, and the other .cpp file with something like
namespace {
const float upperLimit = 2.0f * ge;
} // namespace
bool foo(float a)
{
return a < upperLimit;
}
in it, is it guaranteed that upperLimit is initialized after the ge?
I'm aware about indefinite initialization order of global objects from different translation units. I'd like to be sure if it is true for the case of mixed global and namespace-wide objects.
In your code, ge
is guaranteed to be initialized before upperLimit
but this is nothing to do with namespaces. The case would be the same if you didn't have the namespace. Namespaces have no effect on initialization order.
The code const float ge = 2.2f;
is part of constant initialization, which is part of static initialization, because it is a variable with static storage duration being initialized by a constant expression.
However, in the code const float upperLimit = 2.0f * ge;
, the initializer is NOT a constant expression because the value of ge
is not known. So it is not static initialization (and therefore falls under dynamic initialization).
All static initialization strongly happens before dynamic initialization (C++17 [basic.start.static]/2) so the code is correct.