里飞网

 找回密码
 立即注册
查看: 3734|回复: 0
打印 上一主题 下一主题

C语言字符串与64位整数相互转换atoi64、itoa64

[复制链接]

45

主题

311

帖子

2814

积分

版主

Rank: 7Rank: 7Rank: 7

积分
2814
跳转到指定楼层
楼主
发表于 2022-10-30 21:10:55 | 只看该作者 回帖奖励 |正序浏览 |阅读模式
本帖最后由 阿里兄 于 2022-10-30 21:31 编辑

C语言字符串与64位整数相互转换atoi64、itoa64
因为C语言标准库没有找到字符串与64位整数相互转换的方法,自己实现了一个。
  1. int64_t atoi64(const char* p)
  2. {
  3.     //1.空指针
  4.     if (NULL == p)
  5.     {
  6.         return 0;
  7.     }
  8.     //2.空字符串
  9.     if (*p == '\0')
  10.     {
  11.         return 0;
  12.     }
  13.     //3.跳过空白字符
  14.     while (*p==' ')
  15.     {
  16.         p++;
  17.     }
  18.     //4.处理数字字符的转换
  19.     int64_t n = 0;
  20.     while ( *p>='0' && *p<='9' )//判断是否为10进制字符
  21.     {
  22.         n = n * 10 + (*p - '0');
  23.         p++;
  24.     }
  25.     return n;
  26. }
复制代码
  1. char* itoa64(int64_t num,char* str,int radix)
  2. {
  3.     char index[]="0123456789ABCDEF";//索引表
  4.     int64_t unum;//存放要转换的整数的绝对值,转换的整数可能是负数
  5.     int i=0,j,k;//i用来指示设置字符串相应位,转换之后i其实就是字符串的长度;转换后顺序是逆序的,有正负的情况,k用来指示调整顺序的开始位置;j用来指示调整顺序时的交换。

  6.     //获取要转换的整数的绝对值
  7.     if(radix==10&&num<0)//要转换成十进制数并且是负数
  8.     {
  9.         unum=(int64_t)-num;//将num的绝对值赋给unum
  10.         str[i++]='-';//在字符串最前面设置为'-'号,并且索引加1
  11.     }
  12.     else unum=(int64_t)num;//若是num为正,直接赋值给unum

  13.     //转换部分,注意转换后是逆序的
  14.     do
  15.     {
  16.         str[i++]=index[unum%(unsigned)radix];//取unum的最后一位,并设置为str对应位,指示索引加1
  17.         unum/=radix;//unum去掉最后一位

  18.     }while(unum);//直至unum为0退出循环

  19.     str[i]='\0';//在字符串最后添加'\0'字符,c语言字符串以'\0'结束。

  20.     //将顺序调整过来
  21.     if(str[0]=='-') k=1;//如果是负数,符号不用调整,从符号后面开始调整
  22.     else k=0;//不是负数,全部都要调整

  23.     char temp;//临时变量,交换两个值时用到
  24.     for(j=k;j<=(i-1)/2;j++)//头尾一一对称交换,i其实就是字符串的长度,索引最大值比长度少1
  25.     {
  26.         temp=str[j];//头部赋值给临时变量
  27.         str[j]=str[i-1+k-j];//尾部赋值给头部
  28.         str[i-1+k-j]=temp;//将临时变量的值(其实就是之前的头部值)赋给尾部
  29.     }
  30.     return str;//返回转换后的字符串
  31. }
复制代码


回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|小黑屋|里飞网  

GMT+8, 2024-11-23 19:04 , Processed in 0.071811 second(s), 5 queries , File On.

Powered by Discuz! X3.3

© 2001-2017 Comsenz Inc. Template By 【未来科技】【 www.wekei.cn 】

快速回复 返回顶部 返回列表