In computer programming, a forward declaration is a declaration of an identifier for which the programmer has not yet given a complete definition. It is required for a compiler to know certain properties of an identifier, but not other details, like the particular value it holds or definition. This is particularly useful for one-pass compilers and separate compilation. Forward declaration is used in languages that require declaration before use; it is necessary for mutual recursion in such languages, as it is impossible to define such functions without a forward reference in one definition: one of the functions must be defined first. It is also useful to allow flexible code organization, for example if one wishes to place the main body at the top, and called functions below it. In other languages forward declarations are not necessary, which generally requires instead a multi-pass compiler and for some compilation to be deferred to link time. In these cases identifiers must be defined before they are used in execution, but do not need to be defined before they are used in source code for compilation or interpretation: identifiers do not need to be immediately resolved to an existing entity.
In C and C++, the line above represents a forward declaration of a function and is the function's prototype. After processing this declaration, the compiler would allow the program code to refer tothe entityprintThisInteger in the rest of the program. The definition for a function must be provided somewhere : void printThisInteger
Variables may have only forward declaration and lack definition. During compilation time these are initialized by language specific rules. Variables that are defined in other source/object files must have a forward declaration specified with a keywordextern: int foo; //foo might be defined somewhere in this file extern int bar; //bar must be defined in some other file
In Pascal and other Wirthprogramming languages, it is a general rule that all entities must be declared before use, and thus forward declaration is necessary for mutual recursion, for instance. In C, the same general rule applies, but with an exception for undeclared functions and incomplete types. Thus, in C it is possible to implement a pair of mutually recursive functions thus: int first int second
In Pascal, the same implementation requires a forward declaration of second to precede its use in first. Without the forward declaration, the compiler will produce an error message indicating that the identifier second has been used without being declared.
Classes
In some object-oriented languages like C++ and Objective-C, it is sometimes necessary to forward-declare classes. This is done in situations when it is necessary to know that the name of the class is a type, but where it is unnecessary to know the structure. In C++, classes and structs can be forward-declared like this: class MyClass; struct MyStruct;
In C++, classes can be forward-declared if you only need to use the pointer-to-that-class type. This is especially useful inside class definitions, e.g. if a class contains a member that is a pointer to another class. Forward-declaration is used to avoid unnecessary coupling which help reducing compilation time by reducing the number of header inclusion. This has a triple advantage:
reducing recompilation impact when the forward declared class is modified.
Forward declaration of a class is not sufficient if you need to use the actual class type, for example, if you have a member whose type is that class directly, or if you need to use it as a base class, or if you need to use the methods of the class in a method. In Objective-C, classes and protocols can be forward-declared like this: @class MyClass; @protocol MyProtocol;
In Objective-C, classes and protocols can be forward-declared if you only need to use them as part of an object pointer type, e.g. or. This is especially useful inside class definitions, e.g. if a class contains a member that is a pointer to another class; to avoid circular references, we simply forward-declare the classes instead. Forward declaration of a class or protocol is not sufficient if you need to subclass that class or implement that protocol.
Forward reference
The term forward reference is sometimes used as a synonym of forward declaration. However, more often it is taken to refer to the actual use of an entity before any declaration; that is, the first reference to second in the code above is a forward reference. Thus, we may say that because forward declarations are mandatory in Pascal, forward references are prohibited. An example of forward reference in C++: class C ;
In this example, there are two references to myValue before it is declared. C++ generally prohibits forward references, but they are allowed in the special case of class members. Since the member functionaccessor cannot be compiled until the compiler knows the type of the member variablemyValue, it is the compiler's responsibility to remember the definition of accessor until it sees myValue's declaration. Permitting forward references can greatly increase the complexity and memory requirements of a compiler, and generally prevents the compiler from being implemented in one pass.