Header-only: Difference between revisions
boost link |
No edit summary |
||
(102 intermediate revisions by 75 users not shown) | |||
Line 1: | Line 1: | ||
{{More citations needed|date=January 2019}} |
|||
A library, usually in [[C]] or [[C++]], is called '''header-only''' if the full definitions of all macros, functions and classes comprising the library are visible to the compiler in header, or include-file, form. |
|||
In the context of the [[C (programming language)|C]] or [[C++]] programming languages, a [[library (computing)|library]] is called '''header-only''' if the full definitions of all [[macro (computer science)|macro]]s, [[function (computer science)|function]]s and [[class (computer science)|class]]es comprising the library are visible to the [[compiler]] in a [[header file]] form.<ref name="Wilson-HeaderOnly">{{cite book |
|||
| last = Wilson |
|||
The great advantage of a header-only library is that it does not need to be separately compiled, packaged and installed in order to be used. All that is usually required is to define a suitable environment variable to where it resides, and then #include the file(s) into one's application. |
|||
| first = Matthew |
|||
| year = 2004 |
|||
| title = Imperfect C++ |
|||
| publisher = Addison-Wesley |
|||
| isbn = 0-321-22877-4 |
|||
| page = 177 |
|||
}}</ref> Header-only libraries do not need to be separately [[compiler|compiled]], packaged and installed in order to be used. All that is required is to point the compiler at the location of the headers, and then {{mono|[[C preprocessor|#include]]}} the header files into the application source. Another advantage is that the compiler's optimizer can do a much better job when all the library's source code is available. |
|||
The disadvantages include: |
The disadvantages include: |
||
* brittleness |
* brittleness – most changes to the library will require recompilation of all [[compilation unit]]s using that library, |
||
* longer compilation times |
* longer compilation times – the compilation unit must see the implementation of all components in the included files, rather than just their interfaces, |
||
* |
* machine-[[code bloat]] (arguably) – the necessary use of [[inline function|inline]] statements in non-class functions can lead to code bloat by over-inlining, |
||
* harder to understand as the header contains both the interface and the implementation whereas traditional library separate both. |
|||
Nonetheless, the header-only form is popular because it avoids the (often much more serious) problem of packaging. |
Nonetheless, the header-only form is popular because it avoids the (often much more serious) problem of packaging. |
||
For [[Template (C++)|C++ templates]], including the definitions in header is the only way to compile, since the compiler needs to know the full definition of the templates in order to instantiate. |
|||
== Header-only Libraries == |
|||
==References== |
|||
* [[Boost C++ Libraries]] |
|||
{{reflist}} |
|||
* [[STLSoft C++ Libraries]] |
|||
* [[VOLE Library|VOLE]] |
|||
[[Category:C++]] |
|||
== External Links == |
|||
[[Category:C (programming language) headers|Only]] |
|||
[[Category:C (programming language) libraries]] |
Latest revision as of 08:26, 20 May 2024
This article needs additional citations for verification. (January 2019) |
In the context of the C or C++ programming languages, a library is called header-only if the full definitions of all macros, functions and classes comprising the library are visible to the compiler in a header file form.[1] Header-only libraries do not need to be separately compiled, packaged and installed in order to be used. All that is required is to point the compiler at the location of the headers, and then #include the header files into the application source. Another advantage is that the compiler's optimizer can do a much better job when all the library's source code is available.
The disadvantages include:
- brittleness – most changes to the library will require recompilation of all compilation units using that library,
- longer compilation times – the compilation unit must see the implementation of all components in the included files, rather than just their interfaces,
- machine-code bloat (arguably) – the necessary use of inline statements in non-class functions can lead to code bloat by over-inlining,
- harder to understand as the header contains both the interface and the implementation whereas traditional library separate both.
Nonetheless, the header-only form is popular because it avoids the (often much more serious) problem of packaging.
For C++ templates, including the definitions in header is the only way to compile, since the compiler needs to know the full definition of the templates in order to instantiate.
References
[edit]- ^ Wilson, Matthew (2004). Imperfect C++. Addison-Wesley. p. 177. ISBN 0-321-22877-4.