深入C++实现函数itoa()的分析
更新时间:2020年4月25日 17:46 点击:1357
函数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;
}
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++实现单向循环链表的解决方法
相关文章
- vector是表示可以改变大小的数组的序列容器,本文主要介绍了C++STL标准库std::vector的使用详解,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...2022-03-06
- 这篇文章主要介绍了C++中取余运算的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-02-23
- php语言实现redis的客户端与服务端有一些区别了因为前面介绍过服务端了这里我们来介绍客户端吧,希望文章对各位有帮助。 为了更好的了解redis协议,我们用php来实现...2016-11-25
- 这篇文章主要介绍了C++ string常用截取字符串方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2020-04-25
- 本文通过例子,讲述了C++调用C#的DLL程序的方法,作出了以下总结,下面就让我们一起来学习吧。...2020-06-25
- 有时我们在页面上需要选择数值范围,如购物时选取价格区间,购买主机时自主选取CPU,内存大小配置等,使用直观的滑块条直接选取想要的数值大小即可,无需手动输入数值,操作简单又方便。HTML首先载入jQuery库文件以及jRange相关...2015-03-15
- 本篇文章主要介绍了C++中四种加密算法之AES源代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。...2020-04-25
- 本文实例讲述了JS实现的简洁纵向滑动菜单(滑动门)效果。分享给大家供大家参考,具体如下:这是一款纵向布局的CSS+JavaScript滑动门代码,相当简洁的手法来实现,如果对颜色不满意,你可以试着自己修改CSS代码,这个滑动门将每一...2015-10-21
- 整数拆分,指把一个整数分解成若干个整数的和。本文重点给大家介绍C++ 整数拆分方法详解,非常不错,感兴趣的朋友一起学习吧...2020-04-25
- 这篇文章主要介绍了C++中Sort函数详细解析,sort函数是algorithm库下的一个函数,sort函数是不稳定的,即大小相同的元素在排序后相对顺序可能发生改变...2022-08-18
jQuery+slidereveal实现的面板滑动侧边展出效果
我们借助一款jQuery插件:slidereveal.js,可以使用它控制面板左右侧滑出与隐藏等效果,项目地址:https://github.com/nnattawat/slideReveal。如何使用首先在页面中加载jquery库文件和slidereveal.js插件。复制代码 代码如...2015-03-15- 这篇文章主要介绍了C++万能库头文件在vs中的安装步骤(图文),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-02-23
- 翻板抽奖的实现流程:前端页面提供6个方块,用数字1-6依次表示6个不同的方块,当抽奖者点击6个方块中的某一块时,方块翻转到背面,显示抽奖中奖信息。看似简单的一个操作过程,却包含着WEB技术的很多知识面,所以本文的读者应该熟...2015-10-21
SQLMAP结合Meterpreter实现注入渗透返回shell
sqlmap 是一个自动SQL 射入工具。它是可胜任执行一个广泛的数据库管理系统后端指印, 检索遥远的DBMS 数据库等,下面我们来看一个学习例子。 自己搭建一个PHP+MYSQ...2016-11-25- 这篇文章主要介绍了C++ bitset用法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2020-04-25
- 本篇文章小编并不是为大家讲解string类型的用法,而是讲解我个人比较好奇的问题,就是string 类型占几个字节...2020-04-25
- 复制代码 代码如下: // 第一种写法 $da = date("w"); if( $da == "1" ){ echo "今天是星期一"; }else if( $da == "2" ){ echo "今天是星期二"; }else if( $da == "3" ){ echo "今天是星期三"; }else if( $da == "4"...2013-10-04
- 这篇文章主要为大家详细介绍了C++ Eigen库计算矩阵特征值及特征向量,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...2020-04-25
- 这篇文章主要介绍了VSCode C++多文件编译的简单使用方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下...2021-03-29
- 这篇文章主要介绍了C++ pair的用法实例详解的相关资料,需要的朋友可以参考下...2020-04-25