Linkage determines the visibility and connection method of C symbols between different translation units, and is divided into three types: external, internal and no linkage. External linkage allows symbols to be accessed throughout the program, such as default global variables and functions; internal linkage restricts symbols to be only valid in the current source file and are implemented through static or const; no linkage is used for local variables and is only valid in its scope. Using linkage correctly can avoid duplicate definitions or not finding symbols.
The linkage in C actually talks about how symbols are identified and connected between different translation units. Simply put, it is whether the symbols such as variables and functions can be correctly shared or merged in multiple source files. If you can't figure out the linkage, it is easy to have problems during the compilation and linking stage, such as repeated definitions, no symbols found, etc.

What is linkage?
Linkage literal translation is "connection", which refers to the question of whether the names of variables, functions, etc. are visible and shared between different scopes or different files. It is divided into three types:
- external linkage : Symbols are visible throughout the program and can be accessed by multiple files.
- internal linkage : The symbol is only visible in the current translation unit (that is, the current source file).
- no linkage : The symbol is only valid within the scope where it is defined, such as local variables.
For example, if a global variable is an external linkage by default, multiple source files can access it through extern
; and if static
is added, it becomes internal.

Typical usage of external linkage
Most functions and global variables are external linkages by default. For example:
// a.cpp int globalVar = 10; void foo() { // ... }
// b.cpp extern int globalVar; // Declaration tells the compiler that this variable has been defined elsewhere void bar() { globalVar = 20; // Modify globalVar defined in a.cpp }
In the example above, globalVar
and foo()
both have external linkages, so they can be accessed in multiple source files. This is also the most common requirement when writing multi-file projects.

It should be noted that if both files define global variables with the same name (non-const, non-static), the linker will report an error and prompt to repeatedly define.
How to use internal linkage?
If you want a variable or function to be used only in the current file and not to "expose" it to other files, you can use the static
keyword (you can also use const
to modify global variables in the namespace to implement internal):
// utils.cpp static int helperVar = 0; // Only visible in utils.cpp static void helperFunc() { // Can only be called in utils.cpp}
At this time, even if other files write extern int helperVar;
they cannot access this variable, and an error will be reported during linking.
const
global variable is internal by default, which is why you can define const int Max = 100;
with the same name in multiple source files without error.
There is no linkage
Local variables and function parameters all belong to no linkages, and they are only valid in the code blocks that define them. for example:
void func() { int localVar = 42; // localVar is only visible inside func}
If you try to access it with extern int localVar;
in another function, that won't work.
Small details are easy to ignore
- The
inline
function can have an external linkage after C 17, but it can be repeatedly defined in multiple translation units and no errors will be reported. - If the
constexpr
variable is defined in the header file, it is best to addinline
(from C 17) or declare it withextern
, otherwise it may lead to multiple definitions. - Using anonymous namespaces can replace
static
implementation of internal linkage, with a more modern syntax:
namespace { int secret = 42; } // secret has internal linkage
Basically that's it. It is very helpful to understand the classification and usage scenarios of linkages and to avoid link errors.
The above is the detailed content of Linkage in C. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undress AI Tool
Undress images for free

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

The core of PHP's development of AI text summary is to call external AI service APIs (such as OpenAI, HuggingFace) as a coordinator to realize text preprocessing, API requests, response analysis and result display; 2. The limitation is that the computing performance is weak and the AI ecosystem is weak. The response strategy is to leverage APIs, service decoupling and asynchronous processing; 3. Model selection needs to weigh summary quality, cost, delay, concurrency, data privacy, and abstract models such as GPT or BART/T5 are recommended; 4. Performance optimization includes cache, asynchronous queues, batch processing and nearby area selection. Error processing needs to cover current limit retry, network timeout, key security, input verification and logging to ensure the stable and efficient operation of the system.

Bit operation can efficiently implement the underlying operation of integers, 1. Check whether the i-th bit is 1: Use n&(1

Functions are the basic unit of organizing code in C, used to realize code reuse and modularization; 1. Functions are created through declarations and definitions, such as intadd(inta,intb) returns the sum of the two numbers; 2. Pass parameters when calling the function, and return the result of the corresponding type after the function is executed; 3. The function without return value uses void as the return type, such as voidgreet(stringname) for outputting greeting information; 4. Using functions can improve code readability, avoid duplication and facilitate maintenance, which is the basic concept of C programming.

decltype is a keyword used by C 11 to deduce expression types at compile time. The derivation results are accurate and do not perform type conversion. 1. decltype(expression) only analyzes types and does not calculate expressions; 2. Deduce the variable name decltype(x) as a declaration type, while decltype((x)) is deduced as x due to lvalue expression; 3. It is often used in templates to deduce the return value through tail-set return type auto-> decltype(t u); 4. Complex type declarations can be simplified in combination with auto, such as decltype(vec.begin())it=vec.begin(); 5. Avoid hard-coded classes in templates

C folderexpressions is a feature introduced by C 17 to simplify recursive operations in variadic parameter templates. 1. Left fold (args...) sum from left to right, such as sum(1,2,3,4,5) returns 15; 2. Logical and (args&&...) determine whether all parameters are true, and empty packets return true; 3. Use (std::cout

C's range-basedfor loop improves code readability and reduces errors by simplifying syntax. Its basic structure is for(declaration:range), which is suitable for arrays and STL containers, such as traversing intarr[] or std::vectorvec. Using references (such as conststd::string&name) can avoid copy overhead and can modify element content. Notes include: 1. Do not modify the container structure in the loop; 2. Ensure that the range is effective and avoid the use of freed memory; 3. There is no built-in index and requires manual maintenance of the counter. Mastering these key points allows you to use this feature efficiently and safely.

ABinarySearchTree(BST)isabinarytreewheretheleftsubtreecontainsonlynodeswithvalueslessthanthenode’svalue,therightsubtreecontainsonlynodeswithvaluesgreaterthanthenode’svalue,andbothsubtreesmustalsobeBSTs;1.TheC implementationincludesaTreeNodestructure

Calling Python scripts in C requires implementation through PythonCAPI. First, initialize the interpreter, then import the module and call the function, and finally clean up the resources; the specific steps are: 1. Initialize the Python interpreter with Py_Initialize(); 2. Load the Python script module with PyImport_Import(); 3. Obtain the objective function through PyObject_GetAttrString(); 4. Use PyObject_CallObject() to pass parameters to call the function; 5. Call Py_DECREF() and Py_Finalize() to release the resource and close the interpreter; in the example, hello is successfully called
