十六进制倒序输出

来源:互联网 发布:c语言的引号什么作用 编辑:程序博客网 时间:2024/05/14 03:59

    最近在研究某个厂家机型的接口调试,使用SNMP协议对网元进行管理,其中就有获取网元工作的协议类型,返回的是十六进制的字符串,经过研究,其协议类型刚好是对应十六进制的数据倒序输出的值。这可能是由于网络传输大端模式或小端模式造成的,所以值表示都倒序了。因此要编写一个函数实现对十六进制的倒序输出。

    原来的想法是把字符串中的每一个数字转化成十六进制的1或0保存到数组中,然后倒序再转换回来。但觉得这种方法太麻烦,效率也不好,也坚信一定有算法可以方便的实现,所以去网上搜索了一下,果然找到了一种很好的算法。其原理就是利用左右互换的方式,比如说一个8位的十六进制数,1和8对换,2和7对换,3和6对换,4和5对换。仔细观察一下,就是折半,所以就先对(1-4)与(5-8)进行互换,再在每个子集中,再进行互换,直到最后一一互换后就得到倒序的结果。这种互换的方式只适合2n才可以。

    下面是自己根据实际应用写的demo程序调试,留下记号,以供以后参考。