编程时,经常用到进制转换、字符转换。比如软件界面输入的数字字符串,如何将字符串处理成数字呢?今天就和大家分享一下。
01
字符串转十六进制
代码实现:
void strtohex(char *pbdest, char *pbsrc, int nlen) { char h1,h2; char s1,s2; int i; for (i=0; i { h1 = pbsrc[2*i]; h2 = pbsrc[2*i+1]; s1 = toupper(h1) - 0x30; //toupper 转换为大写字母 if (s1 > 9) s1 -= 7; s2 = toupper(h2) - 0x30; if (s2 > 9) s2 -= 7; pbdest[i] = s1*16 + s2; } }
02
十六进制转字符串
代码实现:
void hextostr(char *pszdest, char *pbsrc, int nlen) { char ddl, ddh; for (int i = 0; i 57) ddh = ddh + 7; if (ddl > 57) ddl = ddl + 7; pszdest[i * 2] = ddh; pszdest[i * 2 + 1] = ddl; } pszdest[nlen * 2] = ''; }
或者:
u16 hex2stringarray (u8 *psrc, u16 srclen, u8 *pobj) { u16 i=0; for(i=0; i { sprintf((char *)(pobj + i * 2), %02x, *(psrc + i)); } *(pobj + i * 2) = ''; return (i * 2); }
效果:十六进制:0x13 0xaa 0x02转为字符串:”13aaa2”
03
字符串转十进制
代码实现: 第一种,如果带负号 这个就是atoi函数的实现:
int my_atoi(const char *str) { int value = 0; int flag = 1; //判断符号 while (*str == ' ') //跳过字符串前面的空格 { str++; } if (*str == '-') //第一个字符若是‘-’,说明可能是负数 { flag = 0; str++; } else if (*str == '+') //第一个字符若是‘+’,说明可能是正数 { flag = 1; str++; }//第一个字符若不是‘+’‘-’也不是数字字符,直接返回0 else if (*str >= '9' || *str 10) *pbdest = 0; tmp = 1; *pbdest = 0; for (i=nlen-1; i>=0; i--) { *pbdest += tmp*(*(pbsrc+i)-'0'); tmp = tmp*10; } }
效果:字符串:”123” 转为 123
第三种:包含转为浮点数
//m^n函数 //返回值:m^n次方. u32 nmea_pow(u8 m,u8 n) { u32 result=1; while(n--)result*=m; return result; } //str转换为数字,以','或者'*'结束 //buf:数字存储区 //dx:小数点位数,返回给调用函数 //返回值:转换后的数值 int nmea_str2num(u8 *buf,u8*dx) { u8 *p=buf; u32 ires=0,fres=0; u8 ilen=0,flen=0,i; u8 mask=0; int res; while(1) //得到整数和小数的长度 { if(*p=='-'){mask|=0x02;p++;}//是负数 if(*p==','||(*p=='*'))break;//遇到结束了 if(*p=='.'){mask|=0x01;p++;}//遇到小数点了 else if(*p>'9'||(*p5)flen=5; //最多取5位小数 *dx=flen; //小数点位数 for(i=0;i { fres+=nmea_pow(10,flen-1-i)*(buf[ilen+1+i]-'0'); } res=ires*nmea_pow(10,flen)+fres; if(mask&0x02)res=-res; return res; }
效果:字符串:”123.456” 先转为 123456,然后除以1000得到123.456
04
十进制转字符串
代码实现: 如果只是单个十进制转字符串,使用sprintf函数就可以了。 如果是十进制数组:
u16 dectostr (u8 *psrc, u16 srclen, u8 *pobj) { u16 i=0; for(i=0; i { sprintf((char *)(pobj + i * 2), %02d, *(psrc + i)); } *(pobj + i * 2) = ''; return (i * 2); }
效果:十进制数组13 14转为字符串“1314”
05
u8、u32转换
举个栗子:ascii码里 这里写图片描述 字符‘a’ , 一个字节8bit ,即u8 十六进制为 0x41 二进制为 0100 0001 而对应的十进制为 65 整型65,4个字节32bit,即u32 十六进制为 0x41 二进制为 0000 0000 0000 0000 0000 0000 0100 0001 将u32数转换成u8数组 注意:这里是字符数组,不是字符串 字符串是以空字符()结尾的char数组
void u32tou8array(uint8_t *buf, uint32_t u32value) { buf[0] = ((u32value >> 24) & 0xff); buf[1] = ((u32value >> 16) & 0xff); buf[2] = ((u32value >> 8) & 0xff); buf[3] = (u32value & 0xff); }
效果:整型 50 转字符数组 {‘’,’’,’’,’2’} u8数组转u32
void u8arraytou32(uint8_t *buf, uint32_t *u32value) { *u32value = (buf[0] <<24) + (buf[1] <<16) + (buf[2] <<8) + (buf[3] <> 8) & 0xff); ppack[1] = (u8)(len & 0xff); 为小端: ppack[0] = (u8)(len & 0xff); ppack[1] = (u8)((len >> 8) & 0xff);
效果:len为数据类型为 u16(short),比如 0x11 0x22,转为u8(usigned char)数组。 大端为:
ppack[0] (0x11 ) ppack[1] (0x22)
小端为:
ppack[0] (0x22) ppack[1] (0x11)
德国电信运营商Deutsche Telekom推自制云游戏服务
承德科胜半自动浆糊贴标机|白酒贴标机|河北贴标机
优恩RJ45网络端口-100M- 以太网口静电放电及雷击浪涌防护 I
ARM7和Cortex-M3比较
2018苏宁易购携手西门子家电启动“新鲜节”为更多的用户畅享智慧生活
C语言常用转换函数实现原理
美国LAFD成为了美国第一个部署“机器人消防车”的消防部门
什么是芯片封装?倒装芯片(FC)底部填充的原因
PDU和SDU的区别在哪
BT和CIH正式达成了业务批发和转售协议
减少杂波干扰的可控硅调速电路设计
轻松为医疗传感器和耗材添加内存、安全性、监控和控制
微软可调节滤光镜专利曝光,多个液晶层可进行模式切换
百度释出新AI算法 可提升肿瘤辨识效率与正确性
飞兆半导体推出符合音频配置插孔标准的FSA8049 MIC/GND交叉点开关
压电式传动器带来不一样的触觉体验
主动红外探测器和被动红外探测器的主要不同
中国新能源发展的六个方面
PowerInt HiperLCS系列的性能特点及应用分析
高性能运算IC的成功关键取决于先进封装技术