• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            隨筆-161  評(píng)論-223  文章-30  trackbacks-0
               上次介紹了一種字符串轉(zhuǎn)化為16進(jìn)制顯示的算法,并封裝成了API,這個(gè)API可用于串口收到數(shù)據(jù)后按16進(jìn)制顯示字符串,這次介紹串口按16進(jìn)制發(fā)送字符串的算法,使用基于字符類型參數(shù)的模板函數(shù)實(shí)現(xiàn)。算法原理是遍歷字符串,將在區(qū)間'0'--'9','A'--'F','a'--'f'的字符轉(zhuǎn)化成對(duì)應(yīng)的16進(jìn)制整數(shù)(范圍為閉區(qū)間0-15),如遇到連續(xù)2個(gè)可以轉(zhuǎn)換的字符,則將它們存儲(chǔ)在一個(gè)無符號(hào)字節(jié)內(nèi),如遇到不能轉(zhuǎn)化的字符,則略過繼續(xù)。代碼如下:
             1/**
             2    @brief 將字符轉(zhuǎn)化為對(duì)應(yīng)的10進(jìn)制數(shù)整數(shù) ASCII版本 
             3    * 若字符不能轉(zhuǎn)化則返回-1
             4*/

             5template<typename charT>
             6inline char ConvertHexChar(charT ch)
             7{
             8    if(ch>=(charT)'0'&&ch<=(charT)'9')
             9        return ch-(charT)'0';
            10    else if(ch>=(charT)'A'&&ch<=(charT)'F')
            11        return ch-(charT)'A'+10;
            12    else if(ch>=(charT)'a'&&ch<=(charT)'f')
            13        return ch-(charT)'a'+10;
            14    else 
            15        return -1;
            16}

            17
            18typedef std::vector<unsigned char> CByteArrayEx;
            19
            20/**
            21    @brief 將字符串轉(zhuǎn)化成對(duì)應(yīng)的16進(jìn)制數(shù)形式存儲(chǔ)
            22    @param template charT 源字符類型
            23    @param src 源數(shù)據(jù)串
            24    @param size 要轉(zhuǎn)換的長度,字符數(shù)
            25    @param ByteArray 存放結(jié)果的字節(jié)數(shù)組
            26
            27    * 如字符串80 12 34 46 AD FF,對(duì)應(yīng)的就是0x80,0x12,0x34,0x46,0xAD,0xFF
            28    該函數(shù)會(huì)自動(dòng)過濾不能轉(zhuǎn)換的字符,可轉(zhuǎn)換字符范圍在0--9,a--f,A--F區(qū)間   
            29*/

            30template<typename charT>
            31inline void StrToHex(const charT* src,size_t len,CByteArrayEx& ByteArray)
            32{
            33    char low = -1, high = -1;
            34    for (size_t n = 0; n < len; )
            35    {
            36        high = ConvertHexChar(src[n++]); 
            37        if (-1 == high)
            38        {
            39            continue;
            40        }

            41        if (n >= len)
            42        {
            43            ByteArray.push_back(high);
            44            break;
            45        }

            46        low = ConvertHexChar(src[n++]);
            47        if (-1 == low)
            48        {
            49            ByteArray.push_back(high);
            50            continue;
            51        }

            52        ByteArray.push_back(high * 16 + low);  
            53    }

            54}

            55
            56/**
            57    @brief 將字符串轉(zhuǎn)化成對(duì)應(yīng)的16進(jìn)制數(shù)形式存儲(chǔ)
            58    @param template charT 源字符類型
            59    @param src 源數(shù)據(jù)串
            60    @param ByteArray 存放結(jié)果的字節(jié)數(shù)組  
            61*/

            62template<typename charT>
            63inline void StrToHex(const charT* src,CByteArrayEx& ByteArray)
            64{
            65    StrToHex(src,select_variable<is_ansi_char<s_charT>::value>(strlen,wcslen)(src),ByteArray);
            66}
             
            posted on 2009-07-12 16:58 春秋十二月 閱讀(3106) 評(píng)論(0)  編輯 收藏 引用 所屬分類: Algorithm
            伊人久久综合无码成人网 | 亚洲精品成人网久久久久久| 97精品伊人久久久大香线蕉| 国产一区二区三区久久| 久久99精品久久久久久齐齐| 久久久久久久91精品免费观看| 国内精品久久久久久久97牛牛 | 国产精品一区二区久久| 国产叼嘿久久精品久久| 99999久久久久久亚洲| 久久www免费人成看片| 久久国产精品一区| 久久伊人精品青青草原高清| 亚洲中文字幕无码一久久区| 久久久久国产一级毛片高清版| 色播久久人人爽人人爽人人片aV| 久久免费高清视频| 久久久久久国产精品美女| 国产一区二区三精品久久久无广告| 偷偷做久久久久网站| 麻豆久久| 久久久中文字幕日本| 国产成人久久精品区一区二区| 色老头网站久久网| 久久国产成人| 成人午夜精品久久久久久久小说| 久久久久久综合网天天| 人人狠狠综合久久亚洲高清| 99久久精品免费看国产一区二区三区| 久久精品国产久精国产果冻传媒 | 国产精品久久久久AV福利动漫 | 人人狠狠综合久久亚洲| 久久99精品久久久久久水蜜桃 | 精品久久久久久国产潘金莲| 最新久久免费视频| 欧美成人免费观看久久| 伊人久久大香线蕉综合网站| 无码任你躁久久久久久| 亚洲国产成人精品91久久久| 一级做a爰片久久毛片看看| 久久九九免费高清视频|