看完这个类,感觉设计这个类的哥们思维不清晰,有点脑残。
这个类进程类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)));
}