I want to understand the external linkage and internal linkage and their difference.
I also want to know the meaning of
const
variables internally link by default unless otherwise declared asextern
.
I want to understand the external linkage and internal linkage and their difference.
I also want to know the meaning of
const
variables internally link by default unless otherwise declared asextern
.
As dudewat said external linkage means the symbol (function or global variable) is accessible throughout your program and internal linkage means that it's only accessible in one translation unit.
You can explicitly control the linkage of a symbol by using the
extern
andstatic
keywords. If the linkage isn't specified then the default linkage isextern
for non-const
symbols andstatic
(internal) forconst
symbols.Note that instead of using
static
for internal linkage it is better to use anonymous namespaces into which you can also putclass
es. The linkage for anonymous namespaces has changed between C++98 and C++11 but the main thing is that they are unreachable from other translation units.Consider following example:
1.cpp
2.cpp
NB: The keyword static plays a double role. When used in the definitions of global variables, it specifies internal linkage. When used in the definitions of the local variables, it specifies that the lifetime of the variable is going to be the duration of the program instead of being the duration of the function.
Hope that helps!
Before talking about the question, it is better to know the term translation unit, program and some basic concepts of C++ (actually linkage is one of them in general) precisely. You will also have to know what is a scope.
I will emphasize some key points, esp. those missing in previous answers.
Linkage is a property of a name, which is introduced by a declaration. Different names can denote same entity (typically, an object or a function). So talking about linkage of an entity is usually nonsense, unless you are sure that the entity will only be referred by the unique name from some specific declarations (usually one declaration, though).
Note an object is an entity, but a variable is not. While talking about the linkage of a variable, actually the name of the denoted entity (which is introduced by a specific declaration) is concerned. The linkage of the name is in one of the three: no linkage, internal linkage or external linkage.
Different translation units can share the same declaration by header/source file (yes, it is the standard's wording) inclusion. So you may refer the same name in different translation units. If the name declared has external linkage, the identity of the entity referred by the name is also shared. If the name declared has internal linkage, the same name in different translation units denotes different entities, but you can refer the entity in different scopes of the same translation unit. If the name has no linkage, you simply cannot refer the entity from other scopes.
(Oops... I found what I have typed was somewhat just repeating the standard wording ...)
There are also some other confusing points which are not covered by the language specification.
__attribute__
or__declspec
) or compiler options, and the image is not the whole program or the object file translated from a translation unit, thus no standard concept can describe it accurately. Since symbol is not a normative term in C++, it is only an implementation detail, even though the related extensions of dialects may have been widely adopted.The linkage rule of namespace scope
const
variable is something special (and particularly different to theconst
object declared in file scope in C language which also has the concept of linkage of identifiers). Since ODR is enforced by C++, it is important to keep no more than one definition of the same variable or function occurred in the whole program except forinline
functions. If there is no such special rule ofconst
, a simplest declaration ofconst
variable with initializers (e.g.= xxx
) in a header or a source file (often a "header file") included by multiple translation units (or included by one translation unit more than once, though rarely) in a program will violate ODR, which makes to useconst
variable as replacement of some object-like macros impossible.Basically
extern linkage
variable is visible in all filesinternal linkage
variable is visible in single file.Explain: const variables internally link by default unless otherwise declared as extern
external linkage
const
global variable isinternal linkage
extern const
global variable isexternal linkage
A pretty good material about linkage in C++
http://www.goldsborough.me/c/c++/linker/2016/03/30/19-34-25-internal_and_external_linkage_in_c++/
When you write an implementation file (
.cpp
,.cxx
, etc) your compiler generates a translation unit. This is the object file from your implementation file plus all the headers you#include
d in it.Internal linkage refers to everything only in scope of a translation unit.
External linkage refers to things that exist beyond a particular translation unit. In other words, accessible through the whole program, which is the combination of all translation units (or object files).
I think Internal and External Linkage in C++ gives a clear and concise explanation: