I’ve got a class (A) that accesses (indirectly via a static method) a static variable (an STL container) in another class (B) in its constructor and destructor.
A objects may be global, global constants, static members of another class, stored in other classes (which may themselves have global or static instances) or basically anywhere else a c++ object can be.
If an A object is constructed before the static members in B or destructed after the static members in B, it will cause a crash at some point (usually an access violation).
Is there some way to guarantee that all instances of class A (except those that have leaked, since by definition there “lost” and so wont be destructed any way) are constructed after and destructed before B’s static variable?
I’ve seen some solutions for making a specific variable be constructed/destructed before/after another, however not a general case of all instances of a given type so am not sure how to approach this.
No. This is known as the static-initialization fiasco. The order that objects get constructed prior to entering main is unspecified. The only guarantee is that it happens.
What you can do is lazy-initialize. This means your objects won’t be initialized until you use them. Such as:
You use
get_Aandget_Bto get the global instances. The part whereBusesAshould useget_A, and your use ofBshould be withget_B. Note theget_Bis optional in your case.What happens when B is first created? (Either globally or in the function) The constructor will call
get_Aand that’s whereAwill be created. This let’s you control the order things get constructed.Note I think I reversed your A and B.