欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解C語(yǔ)言常用的一些轉(zhuǎn)換工具函數(shù)

 更新時(shí)間:2020年11月10日 22:35:27   作者:三啊三水  
這篇文章主要介紹了C語(yǔ)言常用的一些轉(zhuǎn)換工具函數(shù),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

1、字符串轉(zhuǎn)十六進(jìn)制

代碼實(shí)現(xiàn):

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 轉(zhuǎn)換為大寫字母
    if (s1 > 9)
      s1 -= 7;
    s2 = toupper(h2) - 0x30;
    if (s2 > 9)
      s2 -= 7;

    pbDest[i] = s1*16 + s2;
  }
}

2、十六進(jìn)制轉(zhuǎn)字符串

代碼實(shí)現(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<SrcLen;  i++)
  {
    sprintf((char *)(pObj + i * 2), "%02X", *(pSrc + i));
  }
  *(pObj + i * 2) = '\0';
  return (i * 2);
}

效果:十六進(jìn)制:0x13 0xAA 0x02轉(zhuǎn)為字符串:”13AAA2”

3、字符串轉(zhuǎn)十進(jìn)制

代碼實(shí)現(xiàn):

第一種,如果帶負(fù)號(hào) 這個(gè)就是atoi函數(shù)的實(shí)現(xiàn):

int my_atoi(const char *str)
{
  int value = 0;
  int flag = 1; //判斷符號(hào)
  while (*str == ' ') //跳過(guò)字符串前面的空格
  {
    str++;
  }
  if (*str == '-') //第一個(gè)字符若是‘-',說(shuō)明可能是負(fù)數(shù)
  {
    flag = 0;
    str++;
  }
  else if (*str == '+') //第一個(gè)字符若是‘+',說(shuō)明可能是正數(shù)
  {
    flag = 1;
    str++;
  }//第一個(gè)字符若不是‘+'‘-'也不是數(shù)字字符,直接返回0
  else if (*str >= '9' || *str <= '0') 
  {
    return 0;  
  }
  //當(dāng)遇到非數(shù)字字符或遇到‘\0'時(shí),結(jié)束轉(zhuǎn)化
  while (*str != '\0' && *str <= '9' && *str >= '0')
  {
    value = value * 10 + *str - '0'; //將數(shù)字字符轉(zhuǎn)為對(duì)應(yīng)的整形數(shù)
    str++;
  }
  if (flag == 0) //負(fù)數(shù)的情況
  {
    value = -value;
  }
  return value;
}

效果:字符串:”-123” 轉(zhuǎn)為 -123

第二種,如果不帶負(fù)號(hào):

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)為浮點(diǎ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ù)字存儲(chǔ)區(qū)
//dx:小數(shù)點(diǎn)位數(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ù)的長(zhǎng)度
  {
    if(*p=='-'){mask|=0X02;p++;}//是負(fù)數(shù)
    if(*p==','||(*p=='*'))break;//遇到結(jié)束了
    if(*p=='.'){mask|=0X01;p++;}//遇到小數(shù)點(diǎn)了
    else if(*p>'9'||(*p<'0'))  //有非法字符
    {  
      ilen=0;
      flen=0;
      break;
    }  
    if(mask&0X01)flen++;
    else ilen++;
    p++;
  }
  if(mask&0X02)buf++; //去掉負(fù)號(hào)
  for(i=0;i<ilen;i++) //得到整數(shù)部分?jǐn)?shù)據(jù)
  { 
    ires+=NMEA_Pow(10,ilen-1-i)*(buf[i]-'0');
  }
  if(flen>5)flen=5;  //最多取5位小數(shù)
  *dx=flen;      //小數(shù)點(diǎn)位數(shù)
  for(i=0;i<flen;i++) //得到小數(shù)部分?jǐn)?shù)據(jù)
  { 
    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” 先轉(zhuǎn)為 123456,然后除以1000得到123.456

4、十進(jìn)制轉(zhuǎn)字符串

代碼實(shí)現(xiàn):

如果只是單個(gè)十進(jìn)制轉(zhuǎn)字符串,使用sprintf函數(shù)就可以了。

如果是十進(jìn)制數(shù)組:

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

效果:十進(jìn)制數(shù)組13 14轉(zhuǎn)為字符串“1314”

5、u8、u32轉(zhuǎn)換

舉個(gè)栗子:ASCII碼里

這里寫圖片描述 字符‘A' , 一個(gè)字節(jié)8bit ,即u8 十六進(jìn)制為 0x41 二進(jìn)制為 0100 0001

而對(duì)應(yīng)的十進(jìn)制為 65 整型65,4個(gè)字節(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

voidU8ArrayToU32(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、大端小端

最后就是大小端問(wèn)題了。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)

到此這篇關(guān)于詳解C語(yǔ)言常用的一些轉(zhuǎn)換工具函數(shù)的文章就介紹到這了,更多相關(guān)C語(yǔ)言轉(zhuǎn)換工具函數(shù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C語(yǔ)言編程中對(duì)目錄進(jìn)行基本的打開關(guān)閉和讀取操作詳解

    C語(yǔ)言編程中對(duì)目錄進(jìn)行基本的打開關(guān)閉和讀取操作詳解

    這篇文章主要介紹了C語(yǔ)言編程中對(duì)目錄進(jìn)行基本的打開關(guān)閉和讀取操作,是C語(yǔ)言入門學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下
    2015-09-09
  • 基于list循環(huán)刪除元素,迭代器失效的問(wèn)題詳解

    基于list循環(huán)刪除元素,迭代器失效的問(wèn)題詳解

    下面小編就為大家?guī)?lái)一篇基于list循環(huán)刪除元素,迭代器失效的問(wèn)題詳解。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2016-12-12
  • 遞歸形式與非遞歸形式的斐波那契數(shù)列的用法分析

    遞歸形式與非遞歸形式的斐波那契數(shù)列的用法分析

    本篇文章是對(duì)遞歸形式與非遞歸形式的斐波那契數(shù)列的用法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-05-05
  • c語(yǔ)言通過(guò)棧判斷括號(hào)匹配是否配對(duì)

    c語(yǔ)言通過(guò)棧判斷括號(hào)匹配是否配對(duì)

    前面實(shí)現(xiàn)了棧的基本數(shù)據(jù)結(jié)構(gòu),這里來(lái)做一個(gè)聯(lián)系,用棧來(lái)解決一道比較常見(jiàn)的算法題,就是括號(hào)配對(duì)是否滿足規(guī)則,文中有相關(guān)的代碼示例供大家參考,需要的朋友可以參考下
    2023-09-09
  • C++ 實(shí)現(xiàn)自定義類型的迭代器操作

    C++ 實(shí)現(xiàn)自定義類型的迭代器操作

    這篇文章主要介紹了C++ 實(shí)現(xiàn)自定義類型的迭代器操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-12-12
  • C語(yǔ)言內(nèi)存的動(dòng)態(tài)分配比較malloc和realloc的區(qū)別

    C語(yǔ)言內(nèi)存的動(dòng)態(tài)分配比較malloc和realloc的區(qū)別

    這篇文章主要介紹了C語(yǔ)言內(nèi)存的動(dòng)態(tài)分配比較malloc和realloc的區(qū)別,本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是本文的詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-07-07
  • C++實(shí)現(xiàn)將數(shù)組中的值反轉(zhuǎn)

    C++實(shí)現(xiàn)將數(shù)組中的值反轉(zhuǎn)

    這里給大家分享的事一則C++實(shí)現(xiàn)將數(shù)組中的值反轉(zhuǎn)的代碼,取材自《C++程序設(shè)計(jì)》(梁勇著第三版367頁(yè)),有需要的小伙伴可以參考下
    2016-05-05
  • C++中虛繼承時(shí)的構(gòu)造函數(shù)示例詳解

    C++中虛繼承時(shí)的構(gòu)造函數(shù)示例詳解

    在虛繼承中,虛基類是由最終的派生類初始化的,換句話說(shuō),最終派生類的構(gòu)造函數(shù)必須要調(diào)用虛基類的構(gòu)造函數(shù),這跟普通繼承不同,在普通繼承中,派生類構(gòu)造函數(shù)中只能調(diào)用直接基類的構(gòu)造函數(shù),不能調(diào)用間接基類的,所以本文將通過(guò)代碼示例給大家介紹一下C++虛繼承構(gòu)造函數(shù)
    2023-09-09
  • OpenCV 顏色追蹤的示例代碼

    OpenCV 顏色追蹤的示例代碼

    這篇文章主要介紹了OpenCV 顏色追蹤的示例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-01-01
  • STL 的string類怎么啦

    STL 的string類怎么啦

    在我們研究string類犯了什么毛病之前,還讓我先說(shuō)一下如何了解一個(gè)C++的類。我們要了解一個(gè)C++的類,一般來(lái)說(shuō),要從三個(gè)方面入手
    2013-11-11

最新評(píng)論