C 语言整数与字符串相互转换

一、简述

C 语言中整数与字符串的相互转换,有广泛应用的拓展函数(非标准库),也可以自己尝试简单的实现。

二、整数转字符串

1、拓展函数 itoa

itoa (表示 integer to alphanumeric)是把整型数转换成字符串的一个函数。

windows 环境下,在 头文件中有:

char* itoa(int value,char*string,int radix);//value: 要转换的整数,string: 转换后的字符串,radix: 转换进制数,如2,8,10,16 进制等。

函数源码:

char* itoa(int num,char* str,int radix)
{
   char index[]="0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ";//索引表
   unsigned unum;//存放要转换的整数的绝对值,转换的整数可能是负数
   int i=0,j,k;//i用来指示设置字符串相应位,转换之后i其实就是字符串的长度;转换后顺序是逆序的,有正负的情况,k用来指示调整顺序的开始位置;j用来指示调整顺序时的交换。

   //获取要转换的整数的绝对值
   if(radix==10&&num'-';//在字符串最前面设置为'-'号,并且索引加1
   }
   else unum=(unsigned)num;//若是num为正,直接赋值给unum

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

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

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

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

   char temp;//临时变量,交换两个值时用到
   for(j=k;jreturn str;//返回转换后的字符串

}

示例程序:

实例

#include#include
int main()
{
   int number1 = 123456;
   int number2 = -123456;
   char string[16] = {0};
   itoa(number1,string,10);
   printf("数字:%d 转换后的字符串为:%s\n",number1,string);
   itoa(number2,string,10);
   printf("数字:%d 转换后的字符串为:%s\n",number2,string);
   return 0;
}

效果截图:

2、自己简单实现

实现代码:

实例

#include  

char* Int2String(int num,char *str);//函数声明
int main()
{
   int number1 = 123456;
   int number2 = -123456;
   char string[16] = {0};
   Int2String(number1,string);
   printf("数字:%d 转换后的字符串为:%s\n",number1,string);
   Int2String(number2,string);
   printf("数字:%d 转换后的字符串为:%s\n",number2,string);
   return 0;
}

char* Int2String(int num,char *str)//10进制
{
   int i = 0;//指示填充str
   if(num'-';
   }
   //转换
   do
   {
       str[i++] = num%10+48;//取num最低位 字符0~9的ASCII码是48~57;简单来说数字0+48=48,ASCII码对应字符'0'
       num /= 10;//去掉最低位    
   }while(num);//num不为0继续循环
   
   str[i] = '\0';
   
   //确定开始调整的位置
   int j = 0;
   if(str[0]=='-')//如果有负号,负号不用调整
   {
       j = 1;//从第二位开始调整
       ++i;//由于有负号,所以交换的对称轴也要后移1位
   }
   //对称交换
   for(;jreturn str;//返回转换后的值 } 

效果截图:

三、字符串转整数

1、拓展函数

atoi (表示 alphanumeric to integer)是把字符串转换成整型数的一个函数。

windows 环境下,在 头文件中。

int atoi(const char *nptr);//字符串转整数函数,nptr: 要转换的字符串

函数源码

int  atoi(const char *nptr)
{
       return (int)atol(nptr);
}

long  atol(const char *nptr)
{
       int c;              /* 当前要转换的字符(一个一个字符转换成数字) */
       long total;         /* 当前转换结果 */
       int sign;           /* 标志转换结果是否带负号*/

       /*跳过空格,空格不进行转换*/
       while ( isspace((int)(unsigned char)*nptr) )
           ++nptr;

       c = (int)(unsigned char)*nptr++;//获取一个字符准备转换
       sign = c;           /*保存符号标示*/
       if (c == '-' || c == '+')
           c = (int)(unsigned char)*nptr++;    /*跳过'+''-'号,不进行转换*/

       total = 0;//设置转换结果为0

       while (isdigit(c)) {//如果字符是数字
           total = 10 * total + (c - '0');     /* 根据ASCII码将字符转换为对应的数字,并且乘10累积到结果 */
           c = (int)(unsigned char)*nptr++;    /* 取下一个字符 */
       }

        //根据符号指示返回是否带负号的结果
       if (sign == '-')
           return -total;
       else
           return total;  
}

示例程序:

实例

#include#include

int main()
{
   printf("字符串\"123456\"转换为数字:%d\n",atoi("123456"));
   printf("字符串\"-123456\"转换为数字:%d\n",atoi("-123456"));
   return 0;

}

2、自己简单实现

实现源码:

实例

#include

int String2Int(char *str);//函数声明
int main()
{
   printf("字符串\"123456\"转换为数字:%d\n",String2Int("123456"));
   printf("字符串\"-123456\"转换为数字:%d\n",String2Int("-123456"));
   return 0;
}

int String2Int(char *str)//字符串转数字
{
   char flag = '+';//指示结果是否带符号
   long res = 0;
   
   if(*str=='-')//字符串带负号
   {
       ++str;//指向下一个字符
       flag = '-';//将标志设为负号
   }
   //逐个字符转换,并累加到结果res
   while(*str>=48 && *str'0'的ASCII码为48,48-48=0刚好转化为数字0
   }

   if(flag == '-')//处理是负数的情况
   {
       res = -res;
   }

   return (int)res;
}

截图:

四、利用 sprintf() 函数和 sscanf() 函数

整数转字符串

测试代码:

实例

#include

char* Int2String(int num,char *str);//函数声明
int main()
{
   int number1 = 123456;
   int number2 = -123456;
   char string[16] = {0};
   Int2String(number1,string);
   printf("数字:%d 转换后的字符串为:%s\n",number1,string);
   Int2String(number2,string);
   printf("数字:%d 转换后的字符串为:%s\n",number2,string);
   return 0;
}

char* Int2String(int num,char *str)
{
   sprintf(str, "%d", num);

   return str;

}

运行结果:

字符串转整数

测试代码:

实例

#include

int String2Int(char *str);//函数声明
int main()
{
   printf("字符串\"123456\"转换为数字:%d\n",String2Int("123456"));
   printf("字符串\"-123456\"转换为数字:%d\n",String2Int("-123456"));
   return 0;
}

int String2Int(char *str)//字符串转数字
{
   char flag = '+';//指示结果是否带符号
   long res = 0;
   
   if(*str=='-')//字符串带负号
   {
       ++str;//指向下一个字符
       flag = '-';//将标志设为负号
   }
   
   sscanf(str, "%ld", &res);
   if(flag == '-')
   {
       res = -res;
   }
   return (int)res;
}

运行结果:

五、附ASCII码表(部分)

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/208950.html<

(0)
运维的头像运维
上一篇2025-04-09 06:05
下一篇 2025-04-09 06:07

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注