C語言經常使用的一些轉換工具函數收集

一、字符串轉十六進制

代碼實現:web

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

二、十六進制轉字符串

代碼實現:數組

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

效果:十六進制:0x13 0xAA 0x02轉爲字符串:」13AAA2」app

三、字符串轉十進制

代碼實現:函數

第一種,若是帶負號 這個就是atoi函數的實現:ui

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

效果:字符串:」-123」 轉爲 -123url

第二種,若是不帶負號spa

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

效果:字符串:」123」 轉爲 123.net

第三種:包含轉爲浮點數3d

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

效果:字符串:」123.456」 先轉爲 123456,而後除以1000獲得123.456

四、十進制轉字符串

代碼實現:

若是隻是單個十進制轉字符串,使用sprintf函數就能夠了。

若是是十進制數組:

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

效果:十進制數組13 14轉爲字符串「1314」

五、u八、u32轉換

舉個栗子:ASCII碼裏 

這裏寫圖片描述 字符‘A’ , 一個字節8bit ,即u8 十六進制爲 0x41 二進制爲 0100 0001

而對應的十進制爲 65 整型65,4個字節32bit,即u32 十六進制爲 0x41 二進制爲 0000 0000 0000 0000 0000 0000 0100 0001

將u32數轉換成u8數組

注意:這裏是字符數組,不是字符串

字符串是以空字符(\0)結尾的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 轉字符數組 {‘\0’,’\0’,’\0’,’2’}

u8數組轉u32

void U8ArrayToU32(uint8_t *buf, uint32_t *u32Value)
{
    *u32Value = (buf[0] <<24) + (buf[1] <<16) + (buf[2] <<8) + (buf[3] <<0);
}

效果:字符數組 {‘\0’,’\0’,’\0’,’2’}轉爲整型 50

六、大端小端

最後就是大小端問題了。STM32 默認是小端模式的,那麼該如何轉爲大端?

一、轉爲大端

爲大端:
pPack[0] = (u8)((len >> 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)

往期精彩

結構體對齊原則在自定義協議解析時的妙用之法

【爲宏正名】本應寫入教科書的「世界設定」

【爲宏正名】99%人都不知道的"##"裏用法

分享兩個C庫源碼中的移位函數

以爲本次分享的文章對您有幫助,隨手點[在看]並轉發分享,也是對個人支持。

本文分享自微信公衆號 - 嵌入式雲IOT技術圈(gh_d6ff851b4069)。
若有侵權,請聯繫 support@oschina.cn 刪除。
本文參與「OSC源創計劃」,歡迎正在閱讀的你也加入,一塊兒分享。

相關文章
相關標籤/搜索