从包名我们可以看出该类并没有对应用开发者开放,也就是说在google开放的Android API文档中并没有该类的相关介绍;好在Android系统源码是开源的,因此我在解决framework中问题的时候发现了这个工具类,由于工作原因一直没有回头在细细的领会这个工具类的精髓,因此今天花点时间对这个类进行全面的分析一遍,以备不时之需。

首先分析之前,我们需要了解该类使用来进行16禁止转换的,我之前也写过相关的工具类,但是去了解Google的精神还是有必要的。

package com.android.internal.util;

public class HexDump

{

    private final static char[] HEX_DIGITS = { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', 'C', 'D', 'E', 'F' };//十六进制的组成元素

    

    public static String dumpHexString(byte[] array)

    {

        return dumpHexString(array, 0, array.length);

    }

    

    public static String dumpHexString(byte[] array, int offset, int length)

    {

        StringBuilder result = new StringBuilder();

        

        byte[] line = new byte[16];

        int lineIndex = 0;

        

        result.append("\n0x");

        result.append(toHexString(offset));

        

        for (int i = offset ; i < offset + length ; i++)

        {

            if (lineIndex == 16)

            {

                result.append(" ");

                

                for (int j = 0 ; j < 16 ; j++)

                {

                    if (line[j] > ' ' && line[j] < '~')

                    {

                        result.append(new String(line, j, 1));

                    }

                    else

                    {

                        result.append(".");

                    }

                }

                

                result.append("\n0x");

                result.append(toHexString(i));

                lineIndex = 0;

            }

            

            byte b = array[i];

            result.append(" ");

            result.append(HEX_DIGITS[(b >>> 4) & 0x0F]);

            result.append(HEX_DIGITS[b & 0x0F]);

            

            line[lineIndex++] = b;

        }

        

        if (lineIndex != 16)

        {

            int count = (16 - lineIndex) * 3;

            count++;

            for (int i = 0 ; i < count ; i++)

            {

                result.append(" ");

            }

            

            for (int i = 0 ; i < lineIndex ; i++)

            {

                if (line[i] > ' ' && line[i] < '~')

                {

                    result.append(new String(line, i, 1));

                }

                else

                {

                    result.append(".");

                }

            }

        }

        

        return result.toString();

    }

    

    public static String toHexString(byte b)

    {

        return toHexString(toByteArray(b));

    }



    public static String toHexString(byte[] array)

    {

        return toHexString(array, 0, array.length);

    }

    

    public static String toHexString(byte[] array, int offset, int length)

    {

        char[] buf = new char[length * 2];



        int bufIndex = 0;

        for (int i = offset ; i < offset + length; i++)

        {

            byte b = array[i];

            buf[bufIndex++] = HEX_DIGITS[(b >>> 4) & 0x0F];

            buf[bufIndex++] = HEX_DIGITS[b & 0x0F];

        }



        return new String(buf);        

    }

    

    public static String toHexString(int i)

    {

        return toHexString(toByteArray(i));

    }

    

    public static byte[] toByteArray(byte b)

    {

        byte[] array = new byte[1];

        array[0] = b;

        return array;

    }

    

    public static byte[] toByteArray(int i)

    {

        byte[] array = new byte[4];

        

        array[3] = (byte)(i & 0xFF);

        array[2] = (byte)((i >> 8) & 0xFF);

        array[1] = (byte)((i >> 16) & 0xFF);

        array[0] = (byte)((i >> 24) & 0xFF);

        

        return array;

    }

    

    private static int toByte(char c)

    {

        if (c >= '0' && c <= '9') return (c - '0');

        if (c >= 'A' && c <= 'F') return (c - 'A' + 10);

        if (c >= 'a' && c <= 'f') return (c - 'a' + 10);



        throw new RuntimeException ("Invalid hex char '" + c + "'");

    }

    

    public static byte[] hexStringToByteArray(String hexString)

    {

        int length = hexString.length();

        byte[] buffer = new byte[length / 2];



        for (int i = 0 ; i < length ; i += 2)

        {

            buffer[i / 2] = (byte)((toByte(hexString.charAt(i)) << 4) | toByte(hexString.charAt(i+1)));

        }

        

        return buffer;

    }    

}

HexDump.java解析的更多相关文章

  1. HexDump.java解析,android 16进制转换

    HexDump.java解析android 16进制转换 package com.android.internal.util; public class HexDump { private final ...

  2. java解析xml的三种方法

    java解析XML的三种方法 1.SAX事件解析 package com.wzh.sax; import org.xml.sax.Attributes; import org.xml.sax.SAXE ...

  3. atitit.java解析sql语言解析器解释器的实现

    atitit.java解析sql语言解析器解释器的实现 1. 解析sql的本质:实现一个4gl dsl编程语言的编译器 1 2. 解析sql的主要的流程,词法分析,而后进行语法分析,语义分析,构建sq ...

  4. java 解析XML文档

    Java 解析XML文档 一.解析XML文档方式: 1.DOM方式:将整个XML文档读取到内存中,按照XML文件的树状结构图进行解析. 2.SAX方式:基于事件的解析,只需要加载XML中的部分数据,优 ...

  5. Java 解析 XML

    Java 解析 XML 标签: Java基础 XML解析技术有两种 DOM SAX DOM方式 根据XML的层级结构在内存中分配一个树形结构,把XML的标签,属性和文本等元素都封装成树的节点对象 优点 ...

  6. JAVA解析XML的四种方式

    java解析xml文件四种方式 1.介绍 1)DOM(JAXP Crimson解析器) DOM是用与平台和语言无关的方式表示XML文档的官方W3C标准.DOM是以层次结构组织的节点或信息片断的集合.这 ...

  7. JSON 之JAVA 解析

    一.   JSON (JavaScript Object Notation)一种简单的数据格式,比xml更轻巧. Json建构于两种结构:     1.“名称/值”对的集合(A collection ...

  8. Java解析XML汇总(DOM/SAX/JDOM/DOM4j/XPath)

    [目录] 一.[基础知识——扫盲] 二.[DOM.SAX.JDOM.DOM4j简单使用介绍] 三.[性能测试] 四.[对比] 五.[小插曲XPath] 六.[补充] 关键字:Java解析xml.解析x ...

  9. Java 解析epub格式电子书,helloWorld程序,附带源程序和相关jar包

    秀才坤坤出品 一.epub格式电子书 相关材料和源码均在链接中可以下载:http://pan.baidu.com/s/1bnm8YXT 包括 1.JAVA项目工程test_epub,里面包括了jar包 ...

随机推荐

  1. CentOS安装vim

    VMware下CentOS安装成功后,默认自带vi,但vi功能没vim丰富.以下为CentOS中安装vim: 用yum产看源中的vim安装包: [xi@localhost ~]$ yum search ...

  2. JVM性能调优

    摘自:http://uule.iteye.com/blog/2114697 JVM垃圾回收与性能调优总结 JVM调优的几种策略 一.JVM内存模型及垃圾收集算法  1.根据Java虚拟机规范,JVM将 ...

  3. Qt之Concurrent Map和Map-Reduce

    简述 QtConcurrent::map().QtConcurrent::mapped()和QtConcurrent::mappedReduced()函数在一个序列中(例如:QList或QVector ...

  4. Longest Consecutive Sequence [LeetCode]

    Given an unsorted array of integers, find the length of the longest consecutive elements sequence. F ...

  5. 'NSUnknownKeyException' this class is not key value coding-compliant for the key XXX

    错误: Terminating app due to uncaught exception 'NSUnknownKeyException', reason: '[ setValue:forUndefi ...

  6. 数据库索引<一> 索引结构表结构

    有很长时间没有更新博客了,再过几天都2月分了,如果再不更新一篇,我1月分都没有更新,保持连续,今天更新一篇. 最近没有什么看技术方面的东西,游戏,画画搞这些去了.我发现我每年一到年底就是搞这些东西,其 ...

  7. PHP中MySql函数收集

    1.array mysql_fetch_assoc ( resource $result ) 从结果集中取得一行作为关联数组 说明:  返回对应结果集的关联数组,并且继续移动内部数据指针. 参数:re ...

  8. linux 新增挂载新硬盘

    1. 添加磁盘,查看磁盘状况 [root@db1 /]# fdisk -l Disk /dev/sda: 10.7 GB, 10737418240 bytes 255 heads, 63 sector ...

  9. excel的变量

    因需要定制游戏的公式,公式是以一个系数乘以等级,我想达到修改系数,每个等级对应的值就立即显示出来, 但把系数写在一个单元格,一拉,系数单元格也会跟着增长行数--不是我想要的: 但只要把系数单元格改成变 ...

  10. 二模 (5)day1

    第一题: 题目大意:解一元一次方程(只有+-符号): 解题过程:直接处理处两边的x的系数和常数项,字符串的处理即可. 第二题: 题目大意:求逆序对数. 解题过程:直接归并排序. 第三题: 题目大意:多 ...