Microsoft KB Archive/123768

= PRB: Unresolved Externals for Inline Functions =

Article ID: 123768

Article Last Modified on 12/8/2003

-

APPLIES TO


 * Microsoft C/C++ Professional Development System 7.0
 * Microsoft Visual C++ 1.0 Professional Edition
 * Microsoft Visual C++ 1.5 Professional Edition
 * Microsoft Visual C++ 1.51
 * Microsoft Visual C++ 1.52 Professional Edition
 * Microsoft Visual C++ 1.0 Professional Edition
 * Microsoft Visual C++ 2.0 Professional Edition
 * Microsoft Visual C++ 2.1
 * Microsoft Visual C++ 4.0 Standard Edition
 * Microsoft Visual C++ 4.1 Subscription
 * Microsoft Visual C++ 4.2 Professional Edition
 * Microsoft Visual C++ 5.0 Standard Edition
 * Microsoft Visual C++ 4.2 Enterprise Edition
 * Microsoft Visual C++ 5.0 Enterprise Edition
 * Microsoft Visual C++ 4.2 Professional Edition
 * Microsoft Visual C++ 5.0 Professional Edition

-



This article was previously published under Q123768



SYMPTOMS
Calling an inline function defined in a separate source file generates the following errors in Visual C++ 32-bit Edition, versions 2.x and 4.0:

  error LNK2001: unresolved external symbol " "  : error LNK1120: 1 unresolved externals

The 32-bit edition of Visual C++ version 1.0 generates these errors:

  warning LNK4016: unresolved external symbol "::" error LNK1120: 1 unresolved externals

The 16-bit editions generate this error:

  error L2029: '::' : unresolved external

The function is declared in a header (.H) file, defined as an inline function in one source (.CPP) file, and called from a second source (.CPP) file.



CAUSE
Inline functions are not visible outside of the source file where they are defined. The Inline Specifier section in the C++ Language Reference states, "Functions that are declared as inline and that are not class member functions have internal linkage unless otherwise specified."

The Inline Class Member Functions section in the C++ Language Reference states, "A class member function defaults to external linkage unless a definition for that function contains the inline specifier." Query on in the Books On-line for further information.



RESOLUTION
Here are five possible workarounds:

 Declare the inline function with the extern keyword to force external linkage. Note, however, that using extern with class member functions will cause a warning with /Ze, and an error with /Za. -or-

 Move the function definition to the header file so it's included in each translation unit used. -or-

</li> Remove the inline specification. -or-

</li> Force a function version of the inline function to be created in the module that it is defined in. You can do this by referencing the address of the inline function, by assigning it to a function pointer, or by passing it to a function. -or-

</li> Remove the /Ob1 (Only Inline) or /Ob2 (Any suitable) option from the command line and compile with /Ob0 (Disable). The /Ob0 option is the default if no options are specified.

To change these options from within the Visual Workbench for Visual C++ version 4.0, follow these five steps:

<ol> Select the Settings... option from the Build menu.</li> Select the C/C+ Tab in the Project Settings dialog box.</li> Select the Optimizations item in the Category drop-down list box.</li>  Select one of the following items from the In-line function expansion drop-down list box: <pre class="fixed_text">        - Disable *  (/Ob0) - Only __inline (/Ob1) - Any Suitable (/Ob2) </li> Press OK in the Project Settings dialog box.</li></ol>

To change these options from within the Visual Workbench for Visual C++ version 2.x, follow these five steps:

<ol> Select Project.</li> Choose Settings.</li> Change to the Settings for C/C++.</li> Select the Optimizing Category.</li> Choose the inline option from the Inline Function Expansion box.</li></ol>

To change these options from within previous versions of the Visual Workbench, select Options and choose Project. Then choose Compiler. Change the Category to Optimizations, and choose the inline option from the Inline Expansion of Functions box.</li></ul>

<div class="status_section">

STATUS
This behavior is by design.

<div class="moreinformation_section">

Sample Code
/* Compile options needed: /Ob1 or /Ob2 */

/* TEST.H */ class ClassA {      private: int Var; public: ClassA ; ~ClassA ; };

/* TEST1.CPP */ #include "test.h"  void testfunc(void); inline ClassA::ClassA { Var = 6; }; // Inline function definition ClassA::~ClassA {} void main(void) { ClassA test1; testfunc; }

/* TEST2.CPP */ #include "test.h"  void testfunc(void) {      ClassA test2;  // This generates an unresolved external error // on the default constructor when linked }

Additional query words: 8.00 8.00c 9.00

Keywords: kberrmsg kbprb kbcpponly kbcompiler KB123768

-

[mailto:TECHNET@MICROSOFT.COM Send feedback to Microsoft]

© Microsoft Corporation. All rights reserved.