1、字符串轉十六進制
代碼實現:
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; } }
2、十六進制轉字符串
代碼實現:
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”
3、字符串轉十進制
代碼實現:
第一種,如果帶負號 這個就是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 <= '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” 轉為 -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; } } 效果:字符串:”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'||(*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
4、十進制轉字符串
代碼實現:
如果只是單個十進制轉字符串,使用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”
5、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數組
注意:這里是字符數組,不是字符串
字符串是以空字符(\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
6、大端小端
最后就是大小端問題了。STM32 默認是小端模式的,那么該如何轉為大端?
1、轉為大端
為大端: 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)