WritableComparator

看完这个类,感觉设计这个类的哥们思维不清晰,有点脑残。

这个类进程类RawComparator的意思是说,提供了一个两个方法
1.个是通过类比较,1个是通过类的字符流比较。当然侧重后者。

你看看里面管七八糟的方法,如果这个类别不用的方法,马上麻烦设计的大哥能不能设置成私有方法。
   还有 如果通过流比较 还要把构造函数 第二参数 设置成true. 只是要备注说明吧。
   如果不看源代码,只看api的人。真的用不起来这个类。


compare(WritableComparable a, WritableComparable b)

这个比较是比较值的大小

compareBytes(byte[] b1, int s1, int l1,
                                 byte[] b2, int s2, int l2)
这个需要构造参数的第二个参数为true

变量

comparators
private static HashMap<Class, WritableComparator> comparators =
    new HashMap<Class, WritableComparator>(); // registry
为了提高效率把 类型和比较器放到map里

因为hashmap是线程不安全,为了保证线程安全
在用到put的方法上加了synchronized
  public static synchronized void define(Class c,
                                         WritableComparator comparator) {
    comparators.put(c, comparator);
  }



里面很多redaInt ,readLong,readDouble等方法。
是字符串和 int longdouble类型的转换。
具体怎么转换,readVInt 和readInt区别

看我以后的博客
  /** Parse an integer from a byte array. */
  public static int readInt(byte[] bytes, int start) {
    return (((bytes[start  ] & 0xff) << 24) +
            ((bytes[start+1] & 0xff) << 16) +
            ((bytes[start+2] & 0xff) <<  +
            ((bytes[start+3] & 0xff)));

  }

你可能感兴趣的:(comparator)