从包名我们可以看出该类并没有对应用开发者开放,也就是说在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. CentOS6.5配置python开发环境之一:CentOS图形化界面显示

    这两天在配置centos系统下python的开发环境和工具. 刚用centos,做做记录可以方便以后有需要的人...查资料确实挺麻烦的 centos6.5 sublime3 python27 subl ...

  2. Qt之QLineEdit

    简述 QLineEdit是一个单行文本输入框. QLineEdit允许用户输入和编辑单行纯文本,提供了很多有用的编辑功能,包括:撤消和重做.剪切和粘贴.以及拖放(见setDragEnabled()). ...

  3. 172. Factorial Trailing Zeroes -- 求n的阶乘末尾有几个0

    Given an integer n, return the number of trailing zeroes in n!. Note: Your solution should be in log ...

  4. OC 类别(分类)Categroy

    Categroy类别,又称为扩展类,在类的原基础上扩展方法,且不可添加变量,如果扩展的方法与原始类中的方法相同,则会隐藏原始方法,且不可在扩展方法中通过super调用原始方法,这里与继承不同. 定义: ...

  5. c#获取系统时间的方法(转)

      1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 ...

  6. 转 velocity 模板使用总结

    Velocity是一个基于java的模板引擎.它允许任何人仅仅简单的使用模板语言来引用由java代码定义的对象. 当Velocity应用于web开发时,界面设计人员可以和java程序开发人员同步开发一 ...

  7. API 进程、线程函数

    CancelWaitableTimer 这个函数用于取消一个可以等待下去的计时器操作 CallNamedPipe 这个函数由一个希望通过管道通信的一个客户进程调用 ConnectNamedPipe 指 ...

  8. 牛场围栏(vijos 1054)

    题目大意: 给出N种木棍(每种木棍数量无限)的长度(<=3000),每根木棍可以把它切掉[1,M]的长度来得到新的木棍. 求最大的不能被组合出来的长度. 如果任何长度都能组合出来或者最大值没有上 ...

  9. Json数据,日期的转换

    using (SQLiteConnection con = new SQLiteConnection(Constants.DATA_SOURCE)) { con.Open(); using (SQLi ...

  10. IT公司100题-6-根据上排给出十个数,在其下排填出对应的十个数

    问题描述: 给你10分钟时间,根据上排给出十个数,在其下排填出对应的十个数要求下排每个数都是先前上排那十个数在下排出现的次数.上排的十个数如下:[0,1,2,3,4,5,6,7,8,9] 举一个例子, ...