使用HashMap出现的问题

实验中使用HashMap出现的问题

在写关于ScocialNetworkCircle的实验时,老师提供了一份关系文件,文件中有的关系格式为两个相互认识的人的名字,和亲密度。
我想要把这个信息从文件读取之后存在HashMap里这样人物关系就对应了,再将degree存在List里面,degree序号和HashMap里关系的序号一至,这样就可以将关系与亲密度对应。
并且在之后的的错误检测中我使用了这样的策略:
要检测出重复的关系(第一个人名字和第二个人的名字反过来也算在其中),我通过添加关系后HashMap的大小没有改变来做出重复的判断。
这个时候问题出现了!
原来,HashMap中只要Key的值一样就会覆盖之前的Key,想想也对,HashMap中存的是一一对应的关系,怎么会出现一个Key对应多个Value。我通过上网查询得到了解决方法一:
建立这样的List:List>。将HashMap存到List里,就不会出现覆盖的问题了。
这个时候另一个问题出现了!
之前判断重复关系的代码失效了,因为不管怎么重复都不会覆盖,就无法检测出重复的关系。我绞尽脑汁想出了解决方法二:
重新创建一个类APair,这个类和HashMap有异曲同工之处,但自己创建的类,供自己使用自然没有HashMap复杂。APair只能存一组关系,并且两个APair equals的条件是Key和Value都是相同的,这样一搞,重复的关系也好检查了,问题就全部解决了。

总结:要是jdk提供的类不好用就自己创建一个类,符合自己的代码的需求,用起来也舒服。

你可能感兴趣的:(使用HashMap出现的问题)