java程序:set改造成map
逻辑:
set是无序不重复数据元素的集合。
map是另一种set,如果将<key,value>看成一个整体的话,其实就是set。在map中,若用map的keyset()方法将key提取出来,便构成了一个set集合。
所以,就定义一个整体SimpleEntry<K,V>作为元素存入set。
代码:
/*
*SimpleEntry<K,V>作为map对象的存储元素
*/
class SimpleEntry<K, V>
implements Map.Entry<K, V>, Serializable
{
// map中的key不可变
private final K key;
private V value;
public SimpleEntry(K paramK, V paramV)
{
this.key = paramK;
this.value = paramV;
}
public SimpleEntry(Map.Entry<? extends K, ? extends V> paramEntry)
{
this.key = paramEntry.getKey();
this.value = paramEntry.getValue();
}
public K getKey()
{
return this.key;
}
public V getValue()
{
return this.value;
}
public V setValue(V paramV)
{
Object localObject = this.value;
this.value = paramV;
return localObject;
}
public boolean equals(Object paramObject)
{
if (paramObject == this)
{
return true;
}
if (paramObject.getClass() == SimpleEntry.class)
{
SimpleEntry localSimpleEntry = (SimpleEntry)paramObject;
return localSimpleEntry.getKey().equals(getKey());
}
return false;
}
public int hashCode()
{
return this.key == null ? 0 : this.key.hashCode();
}
public String toString()
{
return this.key + "=" + this.value;
}
}
/*
*Set2Map<K, V>继承自hashset,底层是利用hashset来存储,但存储的是<K,V>这样的二元组,所以可以看成是一个map
*/
public class Set2Map<K, V> extends HashSet<SimpleEntry<K, V>>
{
public void clear()
{
super.clear();
}
public boolean containsKey(K paramK)
{
return super.contains(new SimpleEntry(paramK, null));
}
boolean containsValue(Object paramObject)
{
for (SimpleEntry localSimpleEntry : this)
{
if (localSimpleEntry.getValue().equals(paramObject))
{
return true;
}
}
return false;
}
public V get(Object paramObject)
{
for (SimpleEntry localSimpleEntry : this)
{
if (localSimpleEntry.getKey().equals(paramObject))
{
return localSimpleEntry.getValue();
}
}
return null;
}
public V put(K paramK, V paramV)
{
add(new SimpleEntry(paramK, paramV));
return paramV;
}
//内部用了迭代器实现
public void putAll(Map<? extends K, ? extends V> paramMap)
{
for (Iterator localIterator = paramMap.keySet().iterator(); localIterator.hasNext(); ) { Object localObject = localIterator.next();
add(new SimpleEntry(localObject, paramMap.get(localObject)));
}
}
//内部用了迭代器实现
public V removeEntry(Object paramObject)
{
Iterator localIterator = iterator();
while (localIterator.hasNext())
{
SimpleEntry localSimpleEntry = (SimpleEntry)localIterator.next();
if (localSimpleEntry.getKey().equals(paramObject))
{
Object localObject = localSimpleEntry.getValue();
localIterator.remove();
return localObject;
}
}
return null;
}
public int size()
{
return super.size();
}
}
测试程序:
public class Set2MapTest
{
public static void main(String[] paramArrayOfString)
{
Set2Map localSet2Map = new Set2Map();
localSet2Map.put("语文", Integer.valueOf(89));
localSet2Map.put("数学", Integer.valueOf(83));
localSet2Map.put("英文", Integer.valueOf(80));
System.out.println(localSet2Map);
System.out.println(localSet2Map.size());
localSet2Map.removeEntry("数学");
System.out.println("删除key为\"数学\"的Entry之后:" + localSet2Map);
System.out.println("语文成绩:" + localSet2Map.get("语文"));
System.out.println("是否包含\"英文\"key :" + localSet2Map.containsKey("英文"));
System.out.println("是否包含 82 value :" + localSet2Map.containsValue(Integer.valueOf(82)));
localSet2Map.clear();
System.out.println("执行clear()方法之后的集合:" + localSet2Map);
}
}
reference:
1. 《疯狂java,突破程序员基本功的16课》 李刚。
java程序:set改造成map的更多相关文章
- 分享非常有用的Java程序 (关键代码)(五)---把 Array 转换成 Map
原文:分享非常有用的Java程序 (关键代码)(五)---把 Array 转换成 Map import java.util.Map; import org.apache.commons.lang.Ar ...
- Java程序员岗位
Java程序员岗位面试题有哪些? 1.面向对象的特征有哪些方面(1)抽象:抽象就是忽略一个主题中与当前目标无关的那些方面,以便更充分地注意与当前目标有关的方面.抽象并不打算了解全部问题,而只是选择 ...
- Java程序员面试题集(116-135)
摘要:这一部分讲解基于Java的Web开发相关面试题,即便在Java走向没落的当下,基于Java的Web开发因为拥有非常成熟的解决方案,仍然被广泛应用.不管你的Web开发中是否使用框架,JSP和Ser ...
- JAVA基础--容器 Set, List, Map
Colections接口, Iterator接口, Set接口, List接口, Comparable接口, Map接口 Collections类 容器:装各种对象. 所有容器都在java.util里 ...
- 使用linux perf工具生成java程序火焰图
pre.cjk { font-family: "Nimbus Mono L", monospace } p { margin-bottom: 0.1in; line-height: ...
- Efficient&Elegant:Java程序员入门Cpp
最近项目急需C++ 的知识结构,虽说我有过快速学习很多新语言的经验,但对于C++ 老特工我还需保持敬畏(内容太多),本文会从一个Java程序员的角度,制定高效学习路线快速入门C++ . Java是为了 ...
- JAVA程序员面试宝典
程序员面试之葵花宝典 面向对象的特征有哪些方面 1. 抽象:抽象就是忽略一个主题中与当前目标2. 无关的那些方面,3. 以便更充分地注意与当前目标4. 有关的方面.抽象并不5. 打算了解全部问题 ...
- spark之java程序开发
spark之java程序开发 1.Spark中的Java开发的缘由: Spark自身是使用Scala程序开发的,Scala语言是同时具备函数式编程和指令式编程的一种混血语言,而Spark源码是基于Sc ...
- 聊聊阿里社招面试,谈谈“野生”Java程序员学习的道路
引言 很尴尬的是,这个类型的文章其实之前笔者就写过,原文章里,笔者自称LZ(也就是楼主,有人说是老子的简写,笔者只想说,这位同学你站出来,保证不打死你,-_-),原文章名称叫做<回答阿里社招面试 ...
- 编写高质量代码:改善Java程序的151个建议 --[78~92]
编写高质量代码:改善Java程序的151个建议 --[78~92] HashMap中的hashCode应避免冲突 多线程使用Vector或HashTable Vector是ArrayList的多线程版 ...
随机推荐
- Image路径问题
BitmapImage image = new BitmapImage(new Uri("/Pictures/log.png", UriKind.Relative)); evaIm ...
- htmlentities() 函数
Definition and Usage定义和用法 The htmlentities() function converts characters to HTML entities.htmlentit ...
- iBatis 的删除一条记录
Student.xml 设置删除参数的类型,可以是一个对象的 <delete id="delStudent" parameterClass="int" & ...
- 关于C#中的DateTime类型的技巧
* datetime.now.tostring()方法默认的你是无法得到全部的时间的格式的,只能得到日期,得不到具体时间,如果要具体时间,就应该使用 datetime的tostring()重载,dat ...
- java判断字符串是否为空的方法总结
http://blog.csdn.net/qq799499343/article/details/8492672 以下是java 判断字符串是否为空的四种方法: 方法一: 最多人使用的一个方法, 直观 ...
- 拦截器getmodel方法什么时候被调用(没搞懂有什么鸟用,自己搭的项目中用到了这个)
拦截器是Struts2最强大的特性之一,它是一种可以让用户在Action执行之前和Result执行之后进行一些功能处理的机制.Struts2 的预定义拦截器 modelDriven 如果action实 ...
- Jquery不生效
$(document).ready(function(){这个都没有生效, 1.网上查了说是jquery的路劲引入的有问题,经查并不是这个问题 2.换了一个jquery的版本,发现生效了. 原不生效文 ...
- iOS 常见错误:CALayer position contains NaN: [14 nan]
Terminating app due to uncaught exception 'CALayerInvalidGeometry', reason: 'CALayer position contai ...
- [转]Delphi执行CMD命令
今天看到有人在问用代码执行CMD命令的问题,就总结一下用法,也算做个备忘. Delphi中,执行命令或者运行一个程序有2个函数,一个是winexec,一个是shellexecute.这两个大家应该都见 ...
- 浅谈angular框架
最近新接触了一个js框架angular,这个框架有着诸多特性,最为核心的是:MVVM.模块化.自动化双向数据绑定.语义化标签.依赖注入,以上这些全部都是属于angular特性,虽然说它的功能十分的强大 ...