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) << 8) +
((bytes[start+3] & 0xff)));

}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

手把手教你学AI

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值