从包名我们可以看出该类并没有对应用开发者开放,也就是说在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. each用法

    1.数组用法 <script> var s=["s","i","l","e","n",& ...

  2. [bootstrap] 实用的bootstrap模版下载

    https://shapebootstrap.net/ http://shapebootstrap.net/item/1524915-adminlte-dashboard-and-control-pa ...

  3. .net 时间戳和日期互转 【转】http://www.cnblogs.com/zhuiyi/p/5307540.html

    .net 时间戳和日期互转 1.时间戳转日期public static DateTime IntToDateTime(int timestamp){ return TimeZone.CurrentTi ...

  4. php 正则匹配中文

    在javascript中,要判断字符串是中文是很简单的.比如:var str = "php编程";if (/^[\u4e00-\u9fa5]+$/.test(str)) {aler ...

  5. poj1190 生日蛋糕(深搜+剪枝)

    题目链接:poj1190 生日蛋糕 解题思路: 深搜,枚举:每一层可能的高度和半径 确定搜索范围:底层蛋糕的最大可能半径和最大可能高度 搜索顺序:从底层往上搭蛋糕,在同一层尝试时,半径和高度都是从大到 ...

  6. 最小生成树练习3(普里姆算法Prim)

    风萧萧兮易水寒,壮士要去敲代码.本女子开学后再敲了.. poj1258 Agri-Net(最小生成树)水题. #include<cstdio> #include<cstring> ...

  7. URL链接中文参数乱码的若干处理方法

    JAVA 中URL链接中文参数乱码的若干处理方法,现在整理收录如下: 方法一: (1) JS中,在URL参数中确保用UTF-8编码,用js函数encodeURI()编码,例如 url:"xx ...

  8. java中汉字自动转换成拼音

    java中汉字自动转换成拼音 1.需要下载jar包 pinyin4j.2.5.0.jar ,加入到WEB-INF下的lib里边,右键add to bulid path. 2.[代码]PinYinUti ...

  9. 三级菜单---zhufeng

    <!doctype html><html><head><meta charset="utf-8"><title>无标题文 ...

  10. Oracle - PL/SQL Commands

    第一章:日志管理 1.forcing log switches sql> alter system switch logfile; 2.forcing checkpoints sql> a ...