从包名我们可以看出该类并没有对应用开发者开放,也就是说在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. kmeans算法原理以及实践操作(多种k值确定以及如何选取初始点方法)

    kmeans一般在数据分析前期使用,选取适当的k,将数据聚类后,然后研究不同聚类下数据的特点. 算法原理: (1) 随机选取k个中心点: (2) 在第j次迭代中,对于每个样本点,选取最近的中心点,归为 ...

  2. 6/3 Sprint2 看板和燃尽图

  3. Same Tree [LeetCode]

    Problem Description: http://oj.leetcode.com/problems/same-tree/ class Solution { public: bool isSame ...

  4. Response返回JSON数据到前台页面

    转自博文:<Response JSON数据返回>http://blog.csdn.net/anialy/article/details/8665471 简述: 在servlet填充Resp ...

  5. webService—调用webService

    Web service是一个平台独立的,低耦合的,自包含的.基于可编程的web的应用程序,可使用开放的XML(标准通用标记语言下的一个子集)标准来描述.发布.发现.协调和配置这些应用程序,用于开发分布 ...

  6. 判断jQuery元素是否隐藏

    第一种:使用CSS属性 复制代码 代码如下: var display =$('#id').css('display'); if(display == 'none'){    alert("被 ...

  7. Remote Debugging Chrome 结合Genymotion模拟器的移动端web真机调试(转)

    尝试了好多方法,刚开始想用bluestacks调试手机页面,不过在打开chrome的时候,会黑屏,什么也看不了.最后又是更新android系统,又是卸掉bluestacks重新安装,怎么都不行.最后没 ...

  8. js 面试题

    1.用原生js,创建一个无序列表添加到body中,ul下包含5个li,每个li包含一个text类型元素,text元素内容可自定义: <script type="text/javascr ...

  9. java模式之-模板方法模式

    模板方法模式是java设计模式常见的模式之一. <JAVA与模式>中写道: 模板方法模式是类的行为模式.准备一个抽象类,将部分逻辑以具体方法以及具体构造函数的形式实现,然后声明一些抽象方法 ...

  10. Junit4的简单使用

    junit4的简单使用 测试套件的使用 测试类1 package com.westward; import static org.junit.Assert.*; import org.junit.Te ...