测试序列化后的长度

提示:需要用到的类,以及继承关系如下:

1.java.lang.Object
  |__ java.io.OutputStream
           |__ java.io.ByteArrayOutputStream
                  //description
                     public class ByteArrayOutputStream
                     extends OutputStream
                   //method
                     byte[] toByteArray()   //Creates a newly allocated byte array.
2.java.lang.Object
      |__ java.io.OutputStream
               |__ java.io.FilterOutputStream
                        |__ java.io.DataOutputStream
                             //description
                                public class DataOutputStream
                                extends FilterOutputStream
                                implements DataOutput
3. java.lang.Object
      |__ java.io.OutputStream
           // description
               public abstract class OutputStream
               extends Object
                implements Closeable, Flushable
            //mdthods
               void close()
               void flush()
               void write(byte[] b)
               void write(byte[] b, int off, int len)
               abstract void write(int b)
4.org.apache.hadoop.io
Interface Writable
 //description
    public interface Writable
 //methods
   void readFields(DataInput in)
   void write(DataOutput out)
5. java.lang.Object
       |__ org.apache.hadoop.io.IntWritable
              //description
                 public class IntWritableextends Object
                 implements   WritableComparable
               // methods
                   int get()
                   void readFields(DataInput in)
                   void set(int value)
                   void write(DataOutput out)
6. java.lang.Object
      |__ org.apache.hadoop.util.StringUtils
            //description
              public class StringUtils
              extends Object
            //method
               static String byteToHexString(byte[] bytes)
               static String capitalize(String s)
               static String[] split(String str)
               static Path[] stringToPath(String[] str)
               static URI[] stringToURI(String[] str)
               static String uriToString(URI[] uris) 

代码

import java.io.DataOutputStream;
import java.io.ByteArrayOutputStream;
import java.lang.Byte;

import org.apache.hadoop.io.IntWritable;
import org.apache.hadoop.io.IOUtils;
import org.apache.hadoop.util.StringUtils;
public class TestWritable extends IntWritable {

  public static byte[] serialize(IntWritable writable) throws Exception {
    ByteArrayOutputStream out = new ByteArrayOutputStream();
    DataOutputStream dataOut = new DataOutputStream(out);
    writable.write(dataOut);
    dataOut.close();
    return out.toByteArray();
  }

  public static void main(String[] args) throws Exception {
    IntWritable i = new IntWritable();
    i.set(8);
    System.out.println(i.get());
    byte[] bytes = serialize(i);
    System.out.println(bytes.toString().length());
    System.out.println(StringUtils.byteToHexString(bytes));
  }
}

hadoop2.2编程:序列化的更多相关文章

  1. hadoop2.2编程: 重写comparactor

    要点: 类型比较在hadoop的mapreduce中非常重要,主要用来比较keys; hadoop中的RawComparator<T>接口继承自java的comparator, 主要用来比 ...

  2. hadoop2.2编程:使用MapReduce编程实例(转)

    原文链接:http://www.cnblogs.com/xia520pi/archive/2012/06/04/2534533.html 从网上搜到的一篇hadoop的编程实例,对于初学者真是帮助太大 ...

  3. hadoop2.2编程:各种API

    hadoop2.2 API http://hadoop.apache.org/docs/r0.23.9/api/index.html junit API http://junit.org/javado ...

  4. hadoop2.2编程:DFS API 操作

    1. Reading data from a hadoop URL 说明:想要让java从hadoop的dfs里读取数据,则java 必须能够识别hadoop hdfs URL schema, 因此我 ...

  5. hadoop2.2编程:mapreduce编程之二次排序

    mr自带的例子中的源码SecondarySort,我重新写了一下,基本没变. 这个例子中定义的map和reduce如下,关键是它对输入输出类型的定义:(java泛型编程) public static ...

  6. c#基础语言编程-序列化

    引言 程序员在编写应用程序的时候往往要将程序的某些数据存储在内存中,然后将其写入某个文件或是将它传输到网络中的另一台计算机上以实现通讯.这个将程序数据转化成能被存储并传输的格式的过程被称为" ...

  7. ASP.NET Web API编程——序列化与内容协商

    1 多媒体格式化器 多媒体类型又叫MIME类型,指示了数据的格式.在HTTP协议中多媒体类型描述了消息体的格式.一个多媒体类型包括两个字符串:类型和子类型. 例如: text/html.image/p ...

  8. Python高级编程-序列化

    在程序运行的过程中,所有的变量都是在内存中,比如,定义一个dict: dict1 = {'name': 'Rob', 'age': 19, 'score': 90} 可以随时修改变量,比如把age改成 ...

  9. python IO编程-序列化

    原文链接:https://www.liaoxuefeng.com/wiki/0014316089557264a6b348958f449949df42a6d3a2e542c000/00143192607 ...

随机推荐

  1. Android线程与异步消息处理机制

    在程序开发时,对于一些比较耗时的操作,我们通常会为其开辟一个单独的线程来执行,这样可以尽可能的减少用户等待的时间.在Android中,默认情况下,所有的操作都是在主线程中进行的,这个主线程负责管理与U ...

  2. Java之反射的应用

      package com.zheges; import java.util.Date; public class Customer {//JavaBean 对象 private String nam ...

  3. 将Cell中的视图取出传递到根视图

    当我们点击Cell中的某个图片时,图片会有一种从Cell中取出,放大,然后再回到原来的Cell中的效果.我的想法是:当Cell中的图片用button 来显示.当我们点击Cell中的这个button的时 ...

  4. Codevs 4600 [NOI2015]程序自动分析

    4600 [NOI2015]程序自动分析 时间限制: 1 s 空间限制: 256000 KB 题目等级 : 黄金 Gold 传送门 题目描述 Description 在实现程序自动分析的过程中,常常需 ...

  5. Java Lambda简明教程(一)

    Lambda表达式背景 许多热门的编程语言如今都有一个叫做lambda或者闭包的语言特性,包括比较经典的函数式编程语言Lisp,Scheme,也有稍微年轻的语言比如JavaScript,Python, ...

  6. Android学习7--日志信息的使用

    在代码的调试中,日志信息是必不可少的,关于日志信息的使用,接下来,小编简要的说明一下: 日志分为几种:Verbose:从字面上解释,verbose为冗长的,啰嗦的,所以verbose日志信息输出的内容 ...

  7. SSL Programming Tutorial

    SSL Programming Tutorial � Table of Contents [ � Index       This section demonstrates the implement ...

  8. 【搭建开发环境】在 Windows XP 中参与开源项目,搭建 git 和 cygwin 开发环境

    引言 只有一台 Windows XP 家用机,却想在诸如 Git@OSC 之类的开源社区参与开发,本文提供一个入门级的开发环境搭建指引. 涉及工具:Eclipse,EGit,Cygwin. 欢迎来到 ...

  9. jQuery选择器(一)

    1.#id根据给定的ID匹配一个元素. <div id="notMe"><p>id="notMe"</p></div& ...

  10. Wap站总结一

    前段时间负责了公司的wap站前端工作,目前wap站的基础及较为复杂的几张页面都已经出来,现根据自己的一些经验,贴出部分心得,希望对现在或者以后可能会接触到Wap站的一些人有些帮助 一.本次WAP网站的 ...