PRB: gcvt() Generates Exponential Notation for 0.0x

ID: Q37794


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, 16-bit edition, versions 1.0, 1.5
    • Microsoft Visual C++, 32-bit Editions, versions 1.0, 2.0, 4.0, 5.0, 6.0


SYMPTOMS

The gcvt() function returns a value in scientific notation, without regard to the specified precision, when the floating-point value has the form "0.0<x>" and <x> is any sequence of digits.


CAUSE

This is expected behavior for gcvt().


RESOLUTION

If this behavior is not desired, use the fcvt() function to convert the floating-point number to a string.


MORE INFORMATION

The following code demonstrates this behavior:

Sample Code


/*
 * Compile options needed: None
 */ 

#include <stdio.h>
#include <stdlib.h>

char buffer[50];
int precision = 20;

void main(void)
{
   gcvt(-0.1123, precision, buffer);    /* Decimal output */ 
   printf("buffer ........\"%s\"\n", buffer);

   gcvt(-0.0123, precision, buffer);    /* Scientific notation */ 
   printf("buffer ........\"%s\"\n", buffer);
} 

Additional query words:

Keywords : kbCRT kbVC100 kbVC150 kbVC200 kbVC400 kbVC500 kbVC600
Version : 5.1 6.0 6.0a 6.0ax 7.0 1.0 1.5 2
Platform : MS-DOS NT OS/2 WINDOWS
Issue type : kbprb


Last Reviewed: July 6, 1999
© 2000 Microsoft Corporation. All rights reserved. Terms of Use.