欢迎来到代码驿站!

C代码

当前位置:首页 > 软件编程 > C代码

深入C++实现函数itoa()的分析

时间:2022-10-13 14:16:45|栏目:C代码|点击:
函数itoa()是将整数型转换为c语言风格字符串的函数,原型:
char * itoa(int data, char*p, int num);
data是传入的带转化的数字,为整型变量(data的最大值为2的31次方减去1),p是传入的字符型指针,指向存储转换后字符串空间的首地址;num指定要转换成几进制的数字字符串(二进制,八进制,十进制,十六进制)。
如有不足之处,还望指正!!!
复制代码 代码如下:

// TestInheritance.cpp : 定义控制台应用程序的入口点。
//
#include "stdafx.h"
#include <iostream>
#include <string>
#include <math.h>
using namespace std;
int myItoa(int data, char* p, int num)
{
 if (p == NULL)
 {
  return -1;
 }
 if (data < 0)
 {
  *p++ = '-';
  data = 0 - data;
 }
 int temp = 0;
 int flag = 0; //标志位 0-不存储 1-存储
 if (num == 10)
 {//十进制
  for (int i = 0; i < 10; i++)
  {
   temp = static_cast<int>(data / pow(10.0, 9-i));// pow(i,j),求i的j次方,temp取得当前最高位
   if (temp != 0)  //去掉最前面的0
   {
    flag = 1;//将标志位变为1,可以存储
   }
   if (flag != 0)
   {
    *p++ = temp + '0';  //变成字符
    data = data % static_cast<int>(pow(10.0, 9-i));
   }
  }
 }
 else if (num == 2)
 {//二进制
  for (int i = 0; i < 32; i++)
  {
   temp = static_cast<int>(data / pow(2.0, 31-i)); //int型,存储值最大为(2的31次方-1),
   if (temp != 0)
   {
    flag = 1;
   }
   if (flag != 0)
   {
    *p++ = temp + '0';
    data = data % static_cast<int>(pow(2.0, 31 - i));
   }
  }
 }
 else if (num == 16)
 {//十六进制
  for (int i = 0; i < 8; i++)
  {
   temp = static_cast<int>(data / pow(16.0, 7-i));
   if (temp != 0)
   {
    flag = 1;
   }
   if (flag != 0)
   {
    if (temp >= 0 && temp <= 9)
    {
     *p++ = temp + '0';
    }
    else if (temp >= 10 && temp <= 15)
    {
     *p++ = temp - 10 + 'A';
    }
    data = data % static_cast<int>(pow(16.0, 7 - i));
   }
  }
 }
 else if (num == 8)
 {//八进制
  for (int i = 0; i < 16; i++)
  {
   temp = static_cast<int>(data / pow(8.0, 15-i));
   if (temp != 0)
   {
    flag = 1;
   }
   if (flag != 0)
   {
    *p++ = temp + '0';
    data = data % static_cast<int>(pow(8.0, 15-i));
   }
  }
 }
}
int _tmain(int argc, _TCHAR* argv[])

 int i = 100;
 char a[32] ={0};
 char b[32] ={0};
 char c[32] ={0};
 char d[32] ={0};
 cout << i << "的八进制表示为: ";
 myItoa(i, a, 8);
 cout << a << endl;
 cout << i << "的十进制表示为: ";
 myItoa(i, b, 10);
 cout << b << endl;
 cout << i << "的二进制表示为: ";
 myItoa(i, c, 2);
 cout << c << endl;
 cout << i << "的十六进制表示为: ";
 myItoa(i, d, 16);
 cout << d << endl;
 return 0;
}

上一篇:C语言数据结构 快速排序实例详解

栏    目:C代码

下一篇:没有了

本文标题:深入C++实现函数itoa()的分析

本文地址:http://www.codeinn.net/misctech/216271.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有