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

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© wayne7sk 中级黑马   /  2014-3-8 02:54  /  970 人查看  /  2 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

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;
        }

}


评分

参与人数 1技术分 +1 收起 理由
何伟超 + 1

查看全部评分

2 个回复

倒序浏览
我记得毕老师说是底层判断,现在先死记吧,等技术慢慢提高了理解起来才好..

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


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

Map集合跟Set差不多

评分

参与人数 1技术分 +1 收起 理由
何伟超 + 1

查看全部评分

回复 使用道具 举报
if(!newAl.contains(obj)) 中的Al.contains(obj) 你新建了一个ArrayList,ArrayList判断是否存在的contians中用到equals   
contains 的API
如果此列表中包含指定的元素,则返回 true。更确切地讲,当且仅当此列表包含至少一个满足 (o==null ? e==null : o.equals(e)) 的元素 e 时,则返回 true。

评分

参与人数 1技术分 +1 收起 理由
何伟超 + 1

查看全部评分

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