標準/拡張機能 | C/C++ | 依存項目 |
---|---|---|
z/OS® UNIX | 両方 | z/OS V1R5 |
#define _OPEN_SYS_ITOA_EXT
#include <stdlib.h>
char * utoa(unsigned int n, char * buffer, int radix);
(void) sprintf(buffer, "%u", n);
「buffer」は、戻り文字ストリングを示します。基数が OCTAL の場合、utoa() は符号なし整数 n を 8 進定数にフォーマット
設定します。
基数が HEX の場合、utoa() は符号なし整数 n を 16 進定数にフォーマット設
定します。
16 進値は、必要に応じて、小文字の abcdef を含みます。ストリング・ポインター (バッファーと同じ) が戻されます。 無効な基数引数が渡されると、関数は NULL を戻し、errno に EINVAL を設定しま す。
これは非標準関数です。 提供されるプロトタイプは他のプラットフォームのコンパイラーで一般的に使用されていますが、この関数がすべてのプラットフォームであらゆる場合において同じ動作をするという保証はありません。この関数は他のプラットフォームからアプリケーションを移植する場合には役立ち ますが、新規アプリケーションを作成するときには、最大の移植性を確保するために、 この関数の使用は避けるべきです。
/* CELEBU10
This example reads an unsigned int and formats it to decimal,
octal, hexadecimal constants converted to a character string.
*/
#define _OPEN_SYS_ITOA_EXT
#include <stdio.h>
#include <stdlib.h>
int main ()
{
unsigned int i;
char buffer [sizeof(unsigned int)*8+1];
printf ("Enter a number: ");
if (scanf ("%u",&i) == 1) {
utoa (i,buffer,DECIMAL);
printf ("decimal: %s¥n",buffer);
utoa (i,buffer,HEX);
printf ("hexadecimal: %s¥n",buffer);
utoa (i,buffer,OCTAL);
printf ("octal: %s¥n",buffer);
}
return 0;
}
出力
decimal: 1234
hexadecimal: 4d2
octal: 2322