I was recently reading Stroustrups The C++ Programming Language and in the section about Linkage in chapter 9 I came across the following paragraph:
“In C and older C++ programs, the keyword static is (confusingly) used
to mean “use internal linkage”. Don’t use static except inside functions
and classes.”
The problem is that reading further on, the author did not elaborate on why this is bad practice. I use static functions from time to time in my code usually for some simple calculation that is not needed outside the compilation unit, but I never realised this was frowned upon and it is not obvious to me why it is bad. Can anyone shed light on this for me please??
I think that the idea is not to frown upon internal linkage, but to avoid confusion with the new meaning of
static:statichas way too many meanings (declaring stuff with internal linkage, defining local variables with static storage duration, marking non-instance members of classes), so avoiding one of the less intuitive ones is a good thing.Because of this, the C++98 standard provides another way to declare stuff with internal linkage: unnamed namespaces, and deprecates
static“when declaring objects in a namespace scope”.The C++11 standard removed this deprecation (and also changed somehow the semantic of unnamed namespaces, not really requiring internal linkage), so it’s now really a matter of style.