• 【嵌入式C语言】常见数据转化函数


    本文记录【嵌入式C语言】常见数据转化函数

    1.字符串转16进制

    void StrToHex(char *pbDest, char *pbSrc, int nLen)
    {
      char h1,h2;
      char s1,s2;
      int i;
     
        for (i=0; i<nLen/2; 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;
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21

    2.16进制转字符串

    0x13 0xAA 0x02转为字符串:”13AAA2”

    void HexToStr(char *pszDest, char *pbSrc, int nLen)
    {
        char    ddl, ddh;
        for (int i = 0; i < nLen; i++)
        {
            ddh = 48 + pbSrc[i] / 16;
            ddl = 48 + pbSrc[i] % 16;
            if (ddh > 57) ddh = ddh + 7;
            if (ddl > 57) ddl = ddl + 7;
            pszDest[i * 2] = ddh;
            pszDest[i * 2 + 1] = ddl;
        }
        pszDest[nLen * 2] = '\0';
    }
    
    
    u16 Hex2StringArray (u8 *pSrc,  u16 SrcLen, u8 *pObj)
    {
        u16 i=0;
     
        for(i=0;    i<SrcLen;   i++)
        {
            sprintf((char *)(pObj + i * 2), "%02X", *(pSrc + i));
        }
        *(pObj + i * 2) = '\0';
        return  (i * 2);
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27

    3.字符串转10进制

    3.1 带负号

    效果:字符串:”-123” 转为 -123

    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 <= '0') 
        {
            return 0;    
        }
        //当遇到非数字字符或遇到‘\0’时,结束转化
        while (*str != '\0' && *str <= '9' && *str >= '0')
        {
            value = value * 10 + *str - '0'; //将数字字符转为对应的整形数
            str++;
        }
        if (flag == 0) //负数的情况
        {
            value = -value;
        }
        return value;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34

    3.2 不带负号

    效果:字符串:”123” 转为 123

    void StrtoDec(uint32_t *pbDest, char *pbSrc, int nLen)
    {
        int i;
        int tmp=0;
        if(nLen > 10)
            *pbDest = 0;
        tmp = 1;
        *pbDest = 0;
        for (i=nLen-1; i>=0; i--)
        {
            *pbDest += tmp*(*(pbSrc+i)-'0');
            tmp = tmp*10;
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14

    3.3 包含转为浮点数

    字符串:”123.456” 先转为 123456,然后除以1000得到123.456

    //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'||(*p<'0'))   //有非法字符
            {   
                ilen=0;
                flen=0;
                break;
            }   
            if(mask&0X01)flen++;
            else ilen++;
            p++;
        }
        if(mask&0X02)buf++; //去掉负号
        for(i=0;i<ilen;i++) //得到整数部分数据
        {  
            ires+=NMEA_Pow(10,ilen-1-i)*(buf[i]-'0');
        }
        if(flen>5)flen=5;   //最多取5位小数
        *dx=flen;           //小数点位数
        for(i=0;i<flen;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;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49

    4.十进制转字符串

    十进制数组13 14转为字符串“1314”

    u16 DectoStr (u8 *pSrc, u16 SrcLen, u8 *pObj)
    {
        u16 i=0;
     
        for(i=0;    i<SrcLen;   i++)
        {
            sprintf((char *)(pObj + i * 2), "%02d", *(pSrc + i));
        }
        *(pObj + i * 2) = '\0';
        return  (i * 2);
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    5. u8 和 u32 转换

    注意:这里是字符数组,不是字符串,字符串是以空字符(\0)结尾的char数组

    // 整型 50 转字符数组 {‘\0’,’\0’,’\0’,’2’}
    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);
    }
    
    // 效果:字符数组 {‘\0’,’\0’,’\0’,’2’}转为整型 50
    void U8ArrayToU32(uint8_t *buf, uint32_t *u32Value)
    {
        *u32Value = (buf[0] <<24) + (buf[1] <<16) + (buf[2] <<8) + (buf[3] <<0);
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
  • 相关阅读:
    Databend join reorder 策略
    Spring源码深度解析:七、bean的加载① - doGetBean概述
    Git入门
    免费域名证书最新申请方式大全
    veImageX 演进之路:Web 图片加载提速50%
    腾讯T4精心整理总结消息队列+消息协议+RabbitMQ+ActiveMQ+Kafka
    用Markdown写Html和.md也就图一乐,真骚操作还得用来做PPT
    开源多系统启动工具-ventoy
    y93.第六章 微服务、服务网格及Envoy实战 -- Envoy配置(四)
    基于任务调度的企业级分布式批处理方案
  • 原文地址:https://blog.csdn.net/qq_39217004/article/details/134324233