【Hadoop】自定义Hadoop序列化been Demo

package hadoop.mapreduce.serializable;

import org.apache.hadoop.io.Writable;

import java.io.DataInput;
import java.io.DataOutput;
import java.io.IOException;
/*
* 自定义Hadoop序列化
* */
public class MySerializable implements Writable {
    private String name;
    private long up;
    private long down;

    
    public MySerializable() {
        //反射时会使用
    }

    public MySerializable(String name, long up, long down) {
        this.name = name;
        this.up = up;
        this.down = down;
    }

    public String getName() {
        return name;
    }

    public long getUp() {
        return up;
    }

    public long getDown() {
        return down;
    }

    @Override
    public String toString() {
        return "MySerializable{" +
                "up=" + up +
                ", down=" + down +
                '}';
    }

    //序列化到流中
    @Override
    public void write(DataOutput dataOutput) throws IOException {
        dataOutput.writeUTF(name);
        dataOutput.writeLong(up);
        dataOutput.writeLong(down);

    }


    //反序列化
    @Override
    public void readFields(DataInput dataInput) throws IOException {
        //通过反射生成对象
        name=dataInput.readUTF();
        up= dataInput.readLong();
        down= dataInput.readLong();

    }
}

猜你喜欢

转载自blog.csdn.net/qq_34696236/article/details/82810401