Microsoft KB Archive/138567

From BetaArchive Wiki

Article ID: 138567

Article Last Modified on 7/5/2005



APPLIES TO

  • Microsoft Visual C++ 2.0 Professional Edition
  • Microsoft Visual C++ 2.1
  • Microsoft Visual C++ 2.2
  • Microsoft Visual C++ 4.0 Standard Edition
  • Microsoft Visual C++ 4.1 Subscription
  • Microsoft Visual C++ 4.2 Enterprise Edition
  • Microsoft Visual C++ 5.0 Enterprise Edition
  • Microsoft Visual C++ 6.0 Enterprise Edition
  • Microsoft Visual C++ 4.2 Professional Edition
  • Microsoft Visual C++ 5.0 Professional Edition
  • Microsoft Visual C++ 6.0 Professional Edition
  • Microsoft Visual C++ 6.0 Standard Edition
  • Microsoft Visual C++ .NET 2002 Standard Edition
  • Microsoft Visual C++ .NET 2003 Standard Edition



This article was previously published under Q138567

SYMPTOMS

Given a function template G whose definition includes a function call to F that does not depend on a template parameter, the compiler does not bind function names at the point of the template definition. Instead the compiler binds them when the function template is instantiated. This could cause unexpected runtime results.

CAUSE

This is a fairly recent change to the ANSI C++ working paper. The current version of the Microsoft compilers do not support this feature.

STATUS

Microsoft has confirmed this to be a bug in the Microsoft products listed at the beginning of this article.

MORE INFORMATION

Based on the ANSI C++ working paper draft (14.2.7), if a name can be bound at the point of the template definition and it is not a function called in a way that depends on a template parameter, it will be bound at the template definition point and the binding is not affected by later declarations.

Sample Code to Demonstrate Problem

   /* Compile options needed: Default
   */ 

   #include <iostream.h>

   void F(char)  { cout << "In F(char)" << endl; }

   template <class T>
   void G( T t )
   {
       F(1);   // F() is not dependent on T or t
   }

   void F(int) { cout <<"In F(int)" << endl; }

   void main()
   {
       G(2);
       G('a');
   }

   /* The output from the program */ 

   In F(int)
   In F(int)

   /* The output should be */ 

   In F(char)
   In F(char)
 
                


Additional query words: 9.00 10.00 10.10 10.20

Keywords: kbbug kbcpponly kbcompiler KB138567