从包名我们可以看出该类并没有对应用开发者开放,也就是说在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. HTML5自学笔记[ 1 ]新增标签

    新增语义化标签 <header></header>: 用于页面或板块头部. <footer></footer>:用于页面底部. <nav>& ...

  2. Java 集合系列 07 List总结(LinkedList, ArrayList等使用场景和性能分析)

    java 集合系列目录: Java 集合系列 01 总体框架 Java 集合系列 02 Collection架构 Java 集合系列 03 ArrayList详细介绍(源码解析)和使用示例 Java ...

  3. 冲销交货单WS_REVERSE_GOODS_ISSUE

    LOOP AT ITAB. AT END OF VBELN. PERFORM FRM_LOCK_DELIVERY(ZSDS0002) USING ITAB-VBELN. CALL FUNCTION ' ...

  4. 查看Linux硬件配置信息

    在网上找了N久,发现了一篇不错的文档,转载一下: 1.查看机器所有硬件信息: dmidecode |more dmesg |more 这2个命令出来的信息都非常多,所以建议后面使用"|mor ...

  5. Facebook 内部高效工作PPT

    Facebook 内部分享:不论你如何富有,你都赚不到更多的时间,你也回不到过去.没有那么多的假如,只有指针滴答的时光飞逝和你应该好好把握的现在,以下26张PPT的分享将为您带来时间价值管理的技巧. ...

  6. 大作业关于(“有爱”youi)的简介

    我们团队一共四个人,我们足够了解对方的优缺点,能够很好的进行交流沟通.对于一些问题也能有好的方法去解决,我做事情比较讲究高效和尽可能的完美,或者说要做到我自己觉得完美,才会停下来.对于一件事情,我有自 ...

  7. ios基础篇(五)——UITextField的详细使用

    UItextFieldField通常用于外部数据输入,以实现人机交互. 以下是UItextFieldField的属性及常见用法: 1.textField :设置文本框的默认文本. 2.Placehol ...

  8. JBOss启动只能在本机访问的解决办法

    环境CentOS6.4_X64 JBoss:5.1.2 eap 启动:JBOSS_HOME/bin/run.sh 在本机可以通过http://localhost:8080访问,而其他机器无论是通过机器 ...

  9. Json文件放入Assets文件,读取解析并且放入listview中显示。

    package com.lixu.TestJson; import android.app.Activity; import android.content.Context; import andro ...

  10. [css3]文字过多以省略号显示

    text-overflow:ellipsis; 优点: 1.不用通过程序限定字数 2.有利于SEO(实际上并未被截字,只是局限于宽度未被显示而已) width: 某个值; overflow: hidd ...