itoa的源代码实现
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
itoa的源代码实现
由于通过socket传递数据的时候,仅仅能够通过字符串类型,可是,当我们要传递的数据是整型的是,应该怎么办呢?本来我想着使⽤for循环,可是,总感觉太⿇烦了,后来别⼈告诉我能够使⽤itoa,以下是itoa的原型:
char *itoa(int value, char *string, int radix);
举⽐例如以下:
#include <iostream>
#include <cstring>
using namespace std;
int main()
{
char arr[10];
int a=123456;
itoa(a,arr,10);
cout<<arr<<endl;
cout<<strlen(arr)<<endl;
return 0;
}
可是,正在⾼兴的时候,才发如今Unix下没有itoa函数,上⽹上⼀搜,才发现itoa不是标准的C语⾔函数,以下是百度百科中的解释:
itoa是⼴泛应⽤的⾮标准C语⾔扩展函数。
因为它不是标准C语⾔函数,所以不能在全部的编译器中使⽤。
可是,⼤多数的编译器(如Windows上的)通常在<stdlib.h>头⽂件⾥包括这个函数。
在<stdlib.h>中与之有相反功能的函数是atoi。
那应该怎么办呢?
后来同事告诉我,能够使⽤万能的sprintf啊,我恍然⼤悟,以下举⼀个⼩样例:
#include <iostream>
using namespace std;
int main()
{
char arr[10];
int a=123;
sprintf(arr,"%d",a);
cout<<arr<<endl;
}
我当时挺想知道itoa内部究竟是怎么实现的,在⽹上搜了⼀个样例,感觉写的的挺不错的,我把这个实现itoa的源代码的⽂件改动了⼀下,能够执⾏了,以下是源代码:
#include <stdlib.h>
#include <stdio.h>
char *myitoa(int num,char *str,int radix);
int main()
{
int number = -123456;
char string[25];
myitoa(number, string, 16);
printf("integer = %d string = %s\n", number, string);
return 0;
}
/* 实现itoa函数的源码 */
char *myitoa(int num,char *str,int radix)
{
/* 索引表 */
char index[]="0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ";
unsigned unum; /* 中间变量 */
int i=0,j,k;
/* 确定unum的值 */
if(radix==10&&num<0) /* ⼗进制负数 */
{
unum=(unsigned)-num;
str[i++]='-';
}
else unum=(unsigned)num; /* 其它情况 */
/* 逆序 */
do
{
str[i++]=index[unum%(unsigned)radix];
unum/=radix;
}while(unum);
str[i]='\0';
/* 转换 */
if(str[0]=='-') k=1; /* ⼗进制负数 */
else k=0;
/* 将原来的“/2”改为“/2.0”,保证当num在16~255之间,radix等于16时,也能得到正确结果 */
char temp;
for(j=k;j<=(i-k-1)/2.0;j++)
{
temp=str[j];
str[j]=str[i-j-1];
str[i-j-1]=temp;
}
return str;
}
我在⽹上搜memcpy的时候,⽹上有⼀句话“memcpy能够复制随意内容,⽐如字符数组、整型、结构体、类等”,所以我想着使⽤memcpy应该也能够实现上⾯这个问题,希望看过这篇⽂章的不吝赐教⼀下,谢谢!。