INFO: Consecutive Calls to ctime() Overwrite Previous Values

Last reviewed: August 26, 1997
Article ID: Q33795

The information in this article applies to:
  • The C Run-time (CRT), included with: - Microsoft C for MS-DOS, versions 5.1, 6.0, 6.0a, 6.0ax - Microsoft C for OS/2, versions 5.1, 6.0, 6.0a - Microsoft C/C++ for MS-DOS, version 7.0 - Microsoft Visual C++ for Windows, versions 1.0, 1.5 - Microsoft Visual C++ 32-bit Edition, versions 1.0, 2.0, 4.0, 5.0

SUMMARY

Subsequent calls to the ctime() function overwrite the results of a previous call. The code example below demonstrates this behavior by printing the same time for the start time and finish time in its second printf() call. However, the start and finish times should be different. To correct this situation, remove the "ctime(&start)" call from the second printf() call. Then the finish time is later than the start time, as expected.

This is expected behavior. The ctime() function uses one static buffer to store its results. Therefore, when the second ctime() call is made in the printf function, ctime() overwrites the value returned by the first ctime() call.

MORE INFORMATION

Sample Code

   /*
    * Compile options needed: None
    */

   #include <stdio.h>
   #include <time.h>

   time_t start, finish;

   void main(void)
   {
      int i;

      time(&start);

      for (i = 0; i < 30000; i++)
         time(&finish);

      /* If the following statement is used, the start and finish
         times do not differ, as expected:
      */
      printf("Start time was %s and ending time was %s", ctime(&start),
              ctime(&finish));

      /* If the following statements are used instead, the start and
         finish times are different, as expected:

         printf("Start time was %s", ctime(&start));
         printf("and ending time was %s\n", ctime(&finish));
      */
   }
Keywords          : CRTIss kbfasttip
Version           : MS-DOS:5.1,6.0,6.00a,6.00ax,7.0; OS/2:5.1,6.0,6.00a;  WINDOWS:1.0,1.5; WINDOWS NT:1.0,2.0,4.0,5.0
Platform          : MS-DOS NT OS/2 WINDOWS
Issue type        : kbinfo


================================================================================


THE INFORMATION PROVIDED IN THE MICROSOFT KNOWLEDGE BASE IS PROVIDED "AS IS" WITHOUT WARRANTY OF ANY KIND. MICROSOFT DISCLAIMS ALL WARRANTIES, EITHER EXPRESS OR IMPLIED, INCLUDING THE WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. IN NO EVENT SHALL MICROSOFT CORPORATION OR ITS SUPPLIERS BE LIABLE FOR ANY DAMAGES WHATSOEVER INCLUDING DIRECT, INDIRECT, INCIDENTAL, CONSEQUENTIAL, LOSS OF BUSINESS PROFITS OR SPECIAL DAMAGES, EVEN IF MICROSOFT CORPORATION OR ITS SUPPLIERS HAVE BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. SOME STATES DO NOT ALLOW THE EXCLUSION OR LIMITATION OF LIABILITY FOR CONSEQUENTIAL OR INCIDENTAL DAMAGES SO THE FOREGOING LIMITATION MAY NOT APPLY.

Last reviewed: August 26, 1997
© 1998 Microsoft Corporation. All rights reserved. Terms of Use.