1、字符串轉(zhuǎn)十六進(jìn)制
代碼實現(xiàn):
void StrToHex(char *pbDest, char *pbSrc, int nLen)
{
char h1,h2;
char s1,s2;
int i; for (i=0; iif (s1 > 9)
s1 -= 7;
s2 = toupper(h2) - 0x30; if (s2 > 9)
s2 -= 7;
pbDest[i] = s1*16 + s2;
}
}
2、十六進(jìn)制轉(zhuǎn)字符串
代碼實現(xiàn):
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"%02X" , *(pSrc + i));
}
*(pObj + i * 2) = '\0'; return (i * 2);
}
效果:十六進(jìn)制:0x13 0xAA 0x02轉(zhuǎn)為字符串:”13AAA2”
3、字符串轉(zhuǎn)十進(jìn)制
代碼實現(xiàn):
第一種,如果帶負(fù)號 這個就是atoi函數(shù)的實現(xiàn):
int my_atoi(const char *str)
{
int value = 0;
int flag = 1; //判斷符號 while (*str == ' ') //跳過字符串前面的空格
{
str++;
} if (*str == '-') //第一個字符若是‘-’,說明可能是負(fù)數(shù)
{
flag = 0;
str++;
} else if (*str == '+') //第一個字符若是‘+’,說明可能是正數(shù)
{
flag = 1;
str++;
}//第一個字符若不是‘+’‘-’也不是數(shù)字字符,直接返回0 else if (*str >= '9' || *str <= '0')
{ return 0;
}
//當(dāng)遇到非數(shù)字字符或遇到‘\0’時,結(jié)束轉(zhuǎn)化 while (*str != '\0' && *str <= '9' && *str >= '0')
{
value = value * 10 + *str - '0'; //將數(shù)字字符轉(zhuǎn)為對應(yīng)的整形數(shù)
str++;
} if (flag == 0) //負(fù)數(shù)的情況
{
value = -value;
} return value;
}
效果:字符串:”-123” 轉(zhuǎn)為 -123
第二種,如果不帶負(fù)號:
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” 轉(zhuǎn)為 123
第三種:包含轉(zhuǎn)為浮點數(shù):
//m^n函數(shù)
//返回值:m^n次方.
u32 NMEA_Pow(u8 m,u8 n)
{
u32 result=1; while(n--)result*=m; return result;
}
//str轉(zhuǎn)換為數(shù)字,以','或者'*'結(jié)束
//buf:數(shù)字存儲區(qū)
//dx:小數(shù)點位數(shù),返回給調(diào)用函數(shù)
//返回值:轉(zhuǎn)換后的數(shù)值
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) //得到整數(shù)和小數(shù)的長度
{ if(*p=='-'){mask|=0X02;p++;}//是負(fù)數(shù) if(*p==','||(*p=='*'))break;//遇到結(jié)束了 if(*p=='.'){mask|=0X01;p++;}//遇到小數(shù)點了 else if(*p>'9'||(*p<'0')) //有非法字符
{
ilen=0;
flen=0; break;
} if(mask&0X01)flen++; else ilen++;
p++;
} if(mask&0X02)buf++; //去掉負(fù)號 for(i=0;i'0' );
} if(flen>5)flen=5; //最多取5位小數(shù)
*dx=flen; //小數(shù)點位數(shù) for(i=0;i'0');
}
res=ires*NMEA_Pow(10,flen)+fres; if(mask&0X02)res=-res; return res;
}
效果:字符串:”123.456” 先轉(zhuǎn)為 123456,然后除以1000得到123.456
4、十進(jìn)制轉(zhuǎn)字符串
代碼實現(xiàn):
如果只是單個十進(jìn)制轉(zhuǎn)字符串,使用sprintf函數(shù)就可以了。
如果是十進(jìn)制數(shù)組:
u16 DectoStr (u8 *pSrc, u16 SrcLen, u8 *pObj)
{
u16 i=0; for(i=0; i"%02d" , *(pSrc + i));
}
*(pObj + i * 2) = '\0'; return (i * 2);
}
效果:十進(jìn)制數(shù)組13 14轉(zhuǎn)為字符串“1314”
5、u8、u32轉(zhuǎn)換
舉個栗子:ASCII碼里
這里寫圖片描述 字符‘A’ , 一個字節(jié)8bit ,即u8 十六進(jìn)制為 0x41 二進(jìn)制為 0100 0001
而對應(yīng)的十進(jìn)制為 65 整型65,4個字節(jié)32bit,即u32 十六進(jìn)制為 0x41 二進(jìn)制為 0000 0000 0000 0000 0000 0000 0100 0001
將u32數(shù)轉(zhuǎn)換成u8數(shù)組
注意:這里是字符數(shù)組,不是字符串
字符串是以空字符(\0)結(jié)尾的char數(shù)組
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 轉(zhuǎn)字符數(shù)組 {‘\0’,’\0’,’\0’,’2’}
u8數(shù)組轉(zhuǎn)u32
void U8ArrayToU32(uint8_t *buf, uint32_t *u32Value)
{
*u32Value = (buf[0] <<24) + (buf[1] <<16) + (buf[2] <<8) + (buf[3] <<0); }
效果:字符數(shù)組 {‘\0’,’\0’,’\0’,’2’}轉(zhuǎn)為整型 50
6、大端小端
最后就是大小端問題了。STM32 默認(rèn)是小端模式的,那么該如何轉(zhuǎn)為大端?
1、轉(zhuǎn)為大端
為大端:
pPack[0] = (u8)((len >> 8) & 0xFF);
pPack[1] = (u8)(len & 0xFF);
為小端:
pPack[0] = (u8)(len & 0xFF);
pPack[1] = (u8)((len >> 8) & 0xFF);
效果:len為數(shù)據(jù)類型為 u16(short),比如 0x11 0x22,轉(zhuǎn)為u8(usigned char)數(shù)組。
大端為:
pPack[0] (0x11 )
pPack[1] (0x22)
小端為:
pPack[0] (0x22)
pPack[1] (0x11)
-END-
文章來源:芯片之家
免責(zé)聲明:本文內(nèi)容由21ic獲得授權(quán)后發(fā)布,版權(quán)歸原作者所有,本平臺僅提供信息存儲服務(wù)。文章僅代表作者個人觀點,不代表本平臺立場,如有問題,請聯(lián)系我們,謝謝!