熟悉java源码的进来帮个忙,HashSet重复添加是在哪一段代码做到去掉重复的

问题描述

所有的方法,add、remove都是通过调用hashmap的方法实现的。就连size也是。那么是哪一段代码实现了去除重复的呢。请知道的帮忙,先谢谢了。 问题补充:liuqing_2010_07 写道

解决方案

引用set接口在保证不重复做了什么工作,这点是我最疑惑的 1.接口 是对行为的抽象与规范。2.去重复,只是底层一个算法或者策略问题,与接口没有关系。
解决方案二:
/** * Associates the specified value with the specified key in this map. * If the map previously contained a mapping for the key, the old * value is replaced. * * @param key key with which the specified value is to be associated * @param value value to be associated with the specified key * @return the previous value associated with <tt>key</tt>, or * <tt>null</tt> if there was no mapping for <tt>key</tt>. * (A <tt>null</tt> return can also indicate that the map * previously associated <tt>null</tt> with <tt>key</tt>.) */ public V put(K key, V value) { if (key == null) return putForNullKey(value); int hash = hash(key.hashCode()); int i = indexFor(hash, table.length); for (Entry<K,V> e = table[i]; e != null; e = e.next) { Object k; if (e.hash == hash && ((k = e.key) == key || key.equals(k))) { V oldValue = e.value; e.value = value; e.recordAccess(this); return oldValue; } } modCount++; addEntry(hash, key, value, i); return null; }这个是hashmap的put方法的定义,如果key值存在于map中,那么就用new value覆盖掉old value,这样就实现了避免重复.这下楼主所有的疑问都解决了,求给分
解决方案三:
可以看src.zip里面关于HashSet&TreeSet的add(E e)方法的定义呀.private transient NavigableMap<E,Object> m;private static final Object PRESENT = new Object();public boolean add(E e) {return m.put(e, PRESENT)==null; }看到这里就很明显了.当调用HashSet&TreeSet的add方法时,add方法里面的元素其实是保存在一个Map对象的键里面的,这样就可以做到避免重复.
解决方案四:
下面是HashSet中的add方法 public boolean add(E e) {return map.put(e, PRESENT)==null; }//PRESENT is a dumy object .插入到插入到HashMap中的是key,将e作为key了,当然就去掉了重复元素.因为HashMap中的key是唯一的。

时间: 2024-10-30 07:27:22

熟悉java源码的进来帮个忙,HashSet重复添加是在哪一段代码做到去掉重复的的相关文章

java源码阅读方法以及经验

问题描述 java源码阅读方法以及经验 如何更好的阅读java源码,更注重阅读哪些包里面的源码,当然连好的阅读源码的工具也说明一下更好了 解决方案 我在这里假设你在问怎么阅读jdk的源码,java源码这个名字有点奇怪. 你可以build 一个fast debug版本,然后使用debugger去调试你的程序,这样对程序是怎么调用的有很直观的视图. 其次,可以看看jdk里面的regression tests,里面有很多例子. 其次,openjdk提供了netbean的jdk project,你可以很

关于生成java源码的问题

问题描述 最近要做一个通过java源码生成另一套java源码,如根据以下代码:publicclasshelloword{publicStringtest="";publicvoidtest(){/*语句...*/}publicStringtest(){/*语句...*/returnresult;}} 生成如下代码:publicclasshelloword{publicStringtest="";publicvoidtest(){}publicStringtest()

为什么在csdn中下载的java源码导入后有问题

问题描述 为什么在csdn中下载的java源码不是不能导入,就是导入后有问题又找不到作者帮忙,谁能帮我远程看看呢?也希望上传者能有点说明性文档,一般下载者都是初学者,下载了各种问题你说怎么办? 解决方案 解决方案二:具体什么问题呢.是什么错误,是少jar吗?解决方案三:有一个是源代码有点乱,我新建一个项目然后把它复制进去的,也不知道是哪错了,还有一个是没有数据库的自己新建的数据库,然后运行,就出错了,你能否远程呢解决方案四: 解决方案五:引用3楼qq_14942305的回复:缺少spring的j

对象-java源码中一个抽象类初始化方法中包含一个super(),该怎么理解

问题描述 java源码中一个抽象类初始化方法中包含一个super(),该怎么理解 package org.apache.http.params; import java.util.Set; /** * Abstract base class for parameter collections. * Type specific setters and getters are mapped to the abstract, * generic getters and setters. * * @si

java源码-输入年月日信息问题?完全不知道啊

问题描述 输入年月日信息问题?完全不知道啊 这个题目怎么实现啊,一点点的思路都没有,不知道如何去计算,谁能给我个java源码啊???????????????????????? 解决方案 Calendar a = Calendar.getInstance(); a.set(2016, 0, 1); System.out.println(a.get(a.DAY_OF_YEAR)); //当前年月日在当前年的第几天 a.set(年,月-1,日). 解决方案二: #include <stdio.h>

myeclipse-怎样在自己电脑上运行java源码

问题描述 怎样在自己电脑上运行java源码 本人小白一枚,以前用myeclipse做过网站,今天在这里下载了网络白板的java源码,但是用myeclipse导入之后为什么运行不了啊,请问应该怎样能让java'源码在自己电脑上跑起来啊 解决方案 例如d盘下,CaiShu.java 打开开始-运行-输入cmd回车打开命令行窗口 cd d: javac CaiShu.java 将java文件编译为字节码文件 然后用 java Caishu 运行程序. 以上操作是在环境变量配置正确的前提下进行

关于查看Java源码问题

问题描述 关于查看Java源码问题 为什么在Java源码中看不到迭代器Iterator里相关方法是怎么实现的,比如next(),hasnext()等 解决方案 迭代器是接口,方法是由它的子类实现的.可以使用快捷键,双击选中方法名,然后按下Ctrl加T就能看到实现类了. 解决方案二: Java源码问题查看java源码 Java source code怎么查看java api的源码? 解决方案三: 这个你可以在网上直接百度,参考源码啊

Eclipse直接看Java源码(含所需工具)

    还在为看不了java源码烦恼吗?本文根据网上搜集的材料以及亲身安装测试,总结经验如下,希望能够帮助有需要的朋友们,本总结有助于朋友们少走弯路哦!jadclipse可以帮助查看.class文件.   点击下载本文所需工具 方法/步骤 下载java源码反编译工具后,将net.sf.jadclipse_3.3.0.jar拷贝到eclipse的plugins目录下: 再删除eclipse的configuration目录下org.eclipse.update文件, 如果,你的eclipse是开着的

代码-JAVA源码应该怎么分模块进行解析与学习?

问题描述 JAVA源码应该怎么分模块进行解析与学习? 最近看过了JAVA虚拟机这本书,对JAVA源码也产生了兴趣,可是面对这么多的代码,无从下手,所以请大家给一下比较好的建议 解决方案 先找个工作,慢慢学习,在工作中遇到问题的时候,或者有空闲的时候,就开始看源码.可以从一个包一个包开始看.推荐从java.util包开始. 解决方案二: 可以先找几个常用的包看看,比如math,util什么的. 解决方案三: 一般来说,你应该知道源码的功能,按功能来划分模块. 解决方案四: 建议楼主不要单纯的为了看