当前位置:  编程技术>c/c++/嵌入式

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

    来源: 互联网  发布时间:2014-10-16

    本文导语:  函数itoa()是将整数型转换为c语言风格字符串的函数,原型:char * itoa(int data, char*p, int num);data是传入的带转化的数字,为整型变量(data的最大值为2的31次方减去1),p是传入的字符型指针,指向存储转换后字符串空间的...

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

// TestInheritance.cpp : 定义控制台应用程序的入口点。
//
#include "stdafx.h"
#include
#include
#include
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(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(pow(10.0, 9-i));
   }
  }
 }
 else if (num == 2)
 {//二进制
  for (int i = 0; i < 32; i++)
  {
   temp = static_cast(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(pow(2.0, 31 - i));
   }
  }
 }
 else if (num == 16)
 {//十六进制
  for (int i = 0; i < 8; i++)
  {
   temp = static_cast(data / pow(16.0, 7-i));
   if (temp != 0)
   {
    flag = 1;
   }
   if (flag != 0)
   {
    if (temp >= 0 && temp = 10 && temp

    
 
 

您可能感兴趣的文章:

  • 深入C++浮点数无效值定义与判定的解决办法
  • 深入C++可见性与生命期的区别详解
  • 深入C++四种强制类型转换的总结
  • 用C++实现strcpy(),返回一个char*类型的深入分析
  • c++关键字mutable深入解析
  • 深入分析C++中两个大数相乘结果不正确的问题
  • 深入理解:Java是类型安全的语言,而C++是非类型安全的语言
  • 深入理解C++中常见的关键字含义
  • 深入分析C++中执行多个exe文件方法的批处理代码介绍
  • 从汇编看c++中变量类型的深入分析
  • C++ using namespace std 用法深入解析
  • 深入解析C++中的mutable关键字
  • C++实现strcmp字符串比较的深入探讨
  • C++中virtual继承的深入理解
  • Web服务器/前端 iis7站长之家
  • C++ Vector用法深入剖析
  • 深入C++中API的问题详解
  • C++中const的实现机制深入分析
  • 深入C++中inline关键字的使用
  • C++输入输出操作符重载的深入分析
  • 深入mysql YEAR() MONTH() DAYOFMONTH()日期函数的详解
  • 内联函数inline与宏定义深入解析
  • SQL SERVER函数之深入表值函数的处理分析
  • 深入探讨:main函数执行完毕后,是否可能会再执行一段代码?
  • 深入解析函数指针与返回函数的指针
  • 基于memset()函数的深入理解
  • C语言typedef与复杂函数声明问题的深入解析
  • 深入VC回调函数的使用详解
  • strcat函数与strncat函数的深入分析
  • 深入Main函数中的参数argc,argv的使用详解
  • 深入C++中构造函数、拷贝构造函数、赋值操作符、析构函数的调用过程总结
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • 先序遍历二叉树的递归实现与非递归实现深入解析
  • 基于Java实现缓存Cache的深入分析
  • 深入理解goto语句的替代实现方式分析
  • 深入Ajax代理的Java Servlet的实现详解
  • 深入理解memmove()与memcpy()的区别以及实现方法
  • 深入Resource实现多语言支持的应用详解
  • 快速排序的深入详解以及java实现
  • 深入全排列算法及其实现方法
  • 深入理解C#实现快捷键(系统热键)响应的方法
  • 深入Java Robot实现控制鼠标和键盘的方法详解
  • Assert(断言实现机制深入剖析)
  • Oracle数据块实现原理深入解读
  • Android 静默方式实现批量安装卸载应用程序的深入分析
  • 深入理解TextView实现Rich Text--在同一个TextView设置不同字体风格
  • 深入线程安全容器的实现方法
  • 深入分析:用1K内存实现高效I/O的RandomAccessFile类的详解
  • Docker支持更深入的容器日志分析
  • 关于《深入浅出MFC》
  • Linux有没有什么好的高级的书,我要深入,
  • 深入理解linux内核
  • [100分]有没有关于binutils的深入的资料?或者深入底层的资料?
  • 深入理解PHP内核 TIPI
  • 想深入学习Java应该学习哪些东西
  • 哪位有《JSP深入编程》电子版?
  • 想要深入学习LINUX该学什么?
  • 100分求:哪儿有《深入理解linux内核》可供下哉!
  • 如何深入Linux的内核学习?
  • U-BOOT得掌握到什么程序,用不用深入去学
  • 想深入了解操作系统该怎么做
  • 前一阵子学习了shell脚本,如果想深入点了解linux可以看什么书呢
  • 问一个《深入理解计算机系统》中的问题




  • 特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3