黑马程序员技术交流社区

标题: 关于集合的equals的问题。 [打印本页]

作者: wayne7sk    时间: 2014-3-8 02:54
标题: 关于集合的equals的问题。
List集合判断元素是否相同,依据是元素的equals方法。
那我想问的是就下面的例子,复写了equals方法后是在哪里用到复写后的equals方法的??

class Person
{
        private String name;
        private int age;
        Person(String name,int age)
        {
                this.name=name;
                this.age=age;
        }
        public String getName()
        {
                return name;
        }
        public int getAge()
        {
                return age;       
        }
        public boolean equals(Object obj)
        {
                if(!(obj instanceof Person))
                        return false;
                Person p = (Person)obj;

                return this.name.equals(p.name) && this.age==age;
        }
}

class ArryListTest2
{
        public static void sop(Object obj)
        {
                System.out.println(obj);
        }

        public static void main(String[] args)
        {
                ArrayList al=new ArrayList();
                al.add(new Person("lisi01",30));
                al.add(new Person("lisi02",32));
                al.add(new Person("lisi02",32));
                al.add(new Person("lisi03",33));
                al.add(new Person("lisi04",35));
                al.add(new Person("lisi04",35));

                al = singleElement(al);
                Iterator it =al.iterator();
                while(it.hasNext())
                {
                        Person p = (Person)it.next();//要强转!!!!
                       
                        sop(p.getName()+"::"+p.getAge());
                }

        }

        public static ArrayList singleElement(ArrayList al)
        {
                //定义一个临时容器。
                ArrayList newAl= new ArrayList();
                Iterator it =al.iterator();//
                while(it.hasNext())
                {
                        Object obj= it.next();
                        //System.out.println();

                        if(!newAl.contains(obj))
                                newAl.add(obj);

                }
                return newAl;
        }

}



作者: osully    时间: 2014-3-8 09:10
我记得毕老师说是底层判断,现在先死记吧,等技术慢慢提高了理解起来才好..

对于ArrayList集合,判断元素是否存在,或者删元素底层依据都是equals方法。
对于HashSet集合,判断元素是否存在,或者删除元素,底层依据的是hashCode方法和equals方法。


TreeSet集合排序有两种方式,Comparable和Comparator区别:
1:让元素自身具备比较性,需要元素对象实现Comparable接口,覆盖compareTo方法
2:让集合自身具备比较性,需要定义一个实现了Comparator接口的比较器,并覆盖compare方法,并将该类对象作为实际参数传递给TreeSet集合的构造函数。

Map集合跟Set差不多

作者: 谭荣强    时间: 2014-3-8 11:53
if(!newAl.contains(obj)) 中的Al.contains(obj) 你新建了一个ArrayList,ArrayList判断是否存在的contians中用到equals   
contains 的API
如果此列表中包含指定的元素,则返回 true。更确切地讲,当且仅当此列表包含至少一个满足 (o==null ? e==null : o.equals(e)) 的元素 e 时,则返回 true。




欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2