A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 宗士为 中级黑马   /  2012-5-10 18:40  /  1779 人查看  /  1 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

class EntryComparator implements Comparator<Entry<Character, Integer>> {
public int compare(Entry<Character, Integer> o1, Entry<Character, Integer> o2) {
  int valueGap = o1.getValue() - o2.getValue();
  int keyGap = o1.getKey() - o2.getKey();
  return valueGap != 0 ? valueGap : keyGap;
}
}

怎么确定红色区域为什么用那么泛型呢  怎么来的呢  最好说明白点  俺现在就是浆糊
还有就是 解释下 下面这个嵌套类(实在是看不明白  )

public static interface Map.Entry<K,V>映射项(键-值对)。Map.entrySet 方法返回映射的 collection 视图,其中的元素属于此类。获得映射项引用的唯一 方法是通过此 collection 视图的迭代器来实现。这些 Map.Entry 对象 在迭代期间有效;更确切地讲,如果在迭代器返回项之后修改了底层映射,则某些映射项的行为是不确定的,除了通过 setValue 在映射项上执行操作之外。

评分

参与人数 1技术分 +1 收起 理由
攻城狮 + 1 赞一个!

查看全部评分

1 个回复

倒序浏览
例如:Set<Map.Entry<K,V>>
从外望里看,set是个接口,变成set<Map.Entry>,Map.Entry是一个限定set集合存放的类型,
而Map.Entry<K,V>而这个也和上个一样,“k”“ v”分别限定了Map.Entry接口的存放的类型。
而K,V ,可以自己定义,如Map.Entry<String,Integer>.
泛型是在编译时期限定对象的,字节码里就没有泛型了。

评分

参与人数 1技术分 +1 收起 理由
攻城狮 + 1 赞一个!

查看全部评分

回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马