Solved

itoa function (not atoi)

Posted on 1997-09-08
5
2,014 Views
Last Modified: 2006-11-17
I'm looking for a standard function to do integer-to-string conversion.  The comp.lang.c FAQ says to just use sprintf, but I'd rather live without that cruft.  I could swear I found just such a function once while browsing through man pages, but can't locate it again.
0
Comment
Question by:dhm
  • 3
  • 2
5 Comments
 
LVL 3

Accepted Solution

by:
msmits earned 50 total points
Comment Utility
Depends on your platform I guess. My borland compiler supports the following function:

  char *itoa(int value, char *string, int radix);

It is documented in the DOS reference, but mentions portability to the win16, win32 and OS/2 platforms. It also says that it is not standard available in ANSI C, ANSI C++ and UNIX.

0
 
LVL 3

Author Comment

by:dhm
Comment Utility
Oops, I should've specified unix.  I guess I'll have to ask again.  Thanks for the reply.
0
 
LVL 3

Expert Comment

by:msmits
Comment Utility
After consulting a UNIX Sun Solaris system I came up with the following two from the atoi(3) man page:

  char *lltostr(long long value, char *ptr);
  char *ulltostr(unsigned long long value, char *ptr);

Otherwise a standard itoa is not very difficult:

  char *itoa(int val, char *ptr)
  {
    int sign = (val < 0) ? -1 : 1;
    char tmp[16];
    int i = 0, j = 0;

    val = sign * val;
    while (val != 0) {
      tmp[i] = (val % 10) + '0';
      val = val / 10;
      i++;
    }
    if (i == 0) {
      strcpy(ptr, "0");
    } else {
      if (sign == -1) {
        ptr[j] = '-';
        j++;
      }
      while (i != 0) {
        ptr[j] = tmp[i - 1];
        i--;
        j++;
      }
      ptr[j] = '\000';
    }
  }

While this may not be the most efficient solution or it may not even work, as I completely did this without a compiler and some test cases, it shows that the base-10 algorithm is not difficult.

Although I agree that a library function would be better, so you don't have to invent and test such trivial stuff...

0
 
LVL 3

Author Comment

by:dhm
Comment Utility
Thanks for snooping around...I'd found the Solaris functions too, but they don't exist on the other platforms I compile for.  I ended up just writing itoa, ltoa, utoa, and ultoa:

const char *itoa( int n )
{
      static char buf[32]; /* yeech */
      sprintf( buf, "%d", n );
      return buf;
}

Now I've just gotta find out how to do thread-specific static
function data (on all those platforms).  *That* sort of thing is the hard part on library functions like this.  The logic is, as you say, trivial.
0
 
LVL 3

Expert Comment

by:msmits
Comment Utility
There are several solutions:
1. require the caller to pass a valid character buffer

2. malloc the space and require the caller to free it

I find the first solution the 'most' clean.

0

Featured Post

Enabling OSINT in Activity Based Intelligence

Activity based intelligence (ABI) requires access to all available sources of data. Recorded Future allows analysts to observe structured data on the open, deep, and dark web.

Join & Write a Comment

Have you thought about creating an iPhone application (app), but didn't even know where to get started? Here's how: ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ Important pre-programming comments: I’ve never tri…
Summary: This tutorial covers some basics of pointer, pointer arithmetic and function pointer. What is a pointer: A pointer is a variable which holds an address. This address might be address of another variable/address of devices/address of fu…
The goal of this video is to provide viewers with basic examples to understand how to use strings and some functions related to them in the C programming language.
The goal of this video is to provide viewers with basic examples to understand opening and reading files in the C programming language.

763 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

7 Experts available now in Live!

Get 1:1 Help Now