block.java
来自「Hadoop是一个用于运行应用程序在大型集群的廉价硬件设备上的框架。Hadoop」· Java 代码 · 共 136 行
JAVA
136 行
/** * Copyright 2005 The Apache Software Foundation * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */package org.apache.hadoop.dfs;import org.apache.hadoop.io.*;import java.io.*;import java.util.*;/************************************************** * A Block is a Hadoop FS primitive, identified by a * long. * * @author Mike Cafarella **************************************************/class Block implements Writable, Comparable { static { // register a ctor WritableFactories.setFactory (Block.class, new WritableFactory() { public Writable newInstance() { return new Block(); } }); } static Random r = new Random(); /** */ public static boolean isBlockFilename(File f) { if (f.getName().startsWith("blk_")) { return true; } else { return false; } } long blkid; long len; /** */ public Block() { this.blkid = r.nextLong(); this.len = 0; } /** */ public Block(long blkid, long len) { this.blkid = blkid; this.len = len; } /** * Find the blockid from the given filename */ public Block(File f, long len) { String name = f.getName(); name = name.substring("blk_".length()); this.blkid = Long.parseLong(name); this.len = len; } /** */ public long getBlockId() { return blkid; } /** */ public String getBlockName() { return "blk_" + String.valueOf(blkid); } /** */ public long getNumBytes() { return len; } public void setNumBytes(long len) { this.len = len; } /** */ public String toString() { return getBlockName(); } ///////////////////////////////////// // Writable ///////////////////////////////////// public void write(DataOutput out) throws IOException { out.writeLong(blkid); out.writeLong(len); } public void readFields(DataInput in) throws IOException { this.blkid = in.readLong(); this.len = in.readLong(); } ///////////////////////////////////// // Comparable ///////////////////////////////////// public int compareTo(Object o) { Block b = (Block) o; if (getBlockId() < b.getBlockId()) { return -1; } else if (getBlockId() == b.getBlockId()) { return 0; } else { return 1; } } public boolean equals(Object o) { Block b = (Block) o; return (this.compareTo(b) == 0); }}
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?