C 언어 에서 자주 사용 하 는 변환 도구 함수 에 대한 자세 한 설명
코드 구현:
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,16 진수 문자열코드 구현:
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);
}
효과:16 진수:0x 13 0xAA 0x 02 문자열 로 변환:"13AAA 2"3.문자열 10 진 변환
코드 구현:
첫 번 째,마이너스 가 있 으 면 이것 이 바로 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,10 진 문자열
코드 구현:
단일 10 진 문자열 이 라면 sprintf 함 수 를 사용 하면 됩 니 다.
10 진수 그룹 이 라면:
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);
}
효과:10 진수 그룹 13 14 에서 문자열"1314"로 전환5,u8,u32 변환
밤 을 들다
여기에 그림 설명 문자'A'를 쓰 고 한 바이트 8bit,즉 u8 16 진법 은 0x 41 2 진법 은 0100 0001 이다.
이에 대응 하 는 10 진법 은 65 정형 65,4 바이트 32bit,즉 u32 16 진법 은 0x 41 2 진법 은 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','\0','2'}u8 배열 변환 u32
voidU8ArrayToU32(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.대 단 소 단
마지막 으로 대소 단 문제 입 니 다.STM 32 는 기본적으로 작은 엔 드 모드 입 니 다.그러면 어떻게 큰 엔 드 로 전환 해 야 합 니까?
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),예 를 들 어 0x 11 0x 22 로 u8(usigned char)배열 로 전환 합 니 다.대개:
pPack[0] (0x11 )
pPack[1] (0x22)
작은 단 위 는:
pPack[0] (0x22)
pPack[1] (0x11)
여기 서 C 언어 에서 자주 사용 하 는 변환 도구 함수 에 관 한 이 글 은 여기까지 소개 되 었 습 니 다.더 많은 C 언어 변환 도구 함수 내용 은 우리 의 이전 글 을 검색 하거나 아래 의 관련 글 을 계속 조회 하 시기 바 랍 니 다.앞으로 많은 응원 바 랍 니 다!
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
C 언어 체인 시계는 뱀을 탐식하는 작은 게임을 실현한다본고의 실례는 여러분에게 C 언어 체인표가 뱀 탐식 게임을 실현하는 구체적인 코드를 공유하여 참고하도록 하였으며, 구체적인 내용은 다음과 같다. 프로젝트 이름: 뱀놀이 운영 환경: Linux 프로그래밍 언어: C 언...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.