| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1032 人关注过本帖
标题:十六进制数的转换
只看楼主 加入收藏
tangqz2010
Rank: 1
等 级:新手上路
帖 子:3
专家分:0
注 册:2010-10-26
结帖率:50%
收藏
已结贴  问题点数:20 回复次数:3 
十六进制数的转换
在编辑框中定义了一个字符串变量m_str,并赋值为m_str="12 3a 35 1f 4d 25 3b",想把它变成那个十六进制数再发送给接收方,请高手指点怎么进行转换,谢谢了!
搜索更多相关主题的帖子: 十六进制 
2010-11-02 12:37
hahayezhe
Rank: 15Rank: 15Rank: 15Rank: 15Rank: 15
来 自:湖南张家界
等 级:贵宾
威 望:24
帖 子:1386
专家分:6999
注 册:2010-3-8
收藏
得分:6 
接分........
2010-11-02 18:18
红色警戒
Rank: 11Rank: 11Rank: 11Rank: 11
等 级:贵宾
威 望:19
帖 子:444
专家分:2967
注 册:2005-11-20
收藏
得分:6 
去掉空格用sscanf(m_str, "%x", &value);

2010-11-03 09:43
kwbplcz
Rank: 2
等 级:论坛游民
帖 子:12
专家分:51
注 册:2010-11-3
收藏
得分:6 
这个问题其实就是数据的扩展和压缩问题,

例如有数据 0x01,0x02,0x03,长度为3,
则扩展后得到字符串“010203”,长度为6,

又如有字符串“010203”,长度为6,
则压缩后得到字符串 0x01,0x02,0x03,长度为3,


有如下两个函数分别实现数据的扩展和压缩:



//将数据扩展,例如0x12 0xAC 0x0D则扩展为"12AC0D"
//参数:
//pSrc:要扩展的字符串
//pDest:扩展后的字符串
//len:要扩展的字符串的字符个数
//注意:任何字符串都可以扩展

程序代码:
void uti_unpack(unsigned char *pSrc, unsigned char * pDest, int len)
{
    unsigned char ch1, ch2;
    for( int i = 0; i < len; i++ )
    {
        ch1 = (pSrc[i] & 0xF0) >> 4;
        ch2 = pSrc[i] & 0x0F;
        ch1 += ( (ch1 > 9 ) ? 0x37 : 0x30 );
        ch2 += ( (ch2 > 9 ) ? 0x37 : 0x30 );
        pDest[i*2] = ch1;
        pDest[i*2 + 1] = ch2;
    }
}



//将数据压缩,例如"12AC0D"则压缩为0x12 0xAC 0x0D
//参数:
//pSrc:要压缩的字符串
//pDest:压缩后的字符串
//len:要压缩的字符串的字符个数
//注意:要压缩的字符串里的字符只能有"0-9 a-z A-Z"

程序代码:
void uti_pack(unsigned char *pSrc, unsigned char *pDest, int len)
{
        char  ch1, ch2;
        for( int i = 0; i < (len / 2); i++ )
        {
            ch1 = pSrc[i*2];
            ch2 = pSrc[i*2 + 1];
            (ch1 >= 'a' && ch1 <= 'z') ? (ch1 -= 32) : (ch1);
            (ch2 >= 'a' && ch2 <= 'z') ? (ch2 -= 32) : (ch2);
            ch1 -= ( (ch1 > '9' ) ? 0x37 : 0x30 );
            ch2 -= ( (ch2 > '9' ) ? 0x37 : 0x30 );
            pDest[i] = ( ch1 << 4 ) | ch2;
        }
}


也可以参看这个帖子:
http://bbs.bccn.net/viewthread.php?tid=324089&page=1#pid1867221


[ 本帖最后由 kwbplcz 于 2010-11-3 16:39 编辑 ]

真的不想研究技术.
2010-11-03 16:37
快速回复:十六进制数的转换
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.021354 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved