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; 
} 


扩展阅读: http://baike.baidu.com/view/982195.htm

 

我在网上搜memcpy的时候,网上有一句话“memcpy可以复制任意内容,例如字符数组、整型、结构体、类等”,所以我想着使用memcpy应该也可以实现上面这个问题,希望看过这篇文章的指教一下,谢谢!

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值