详述ArrayList类contains方法

源码:
contains方法

public boolean contains(Object o) {
	return indexOf(o) >= 0;
}

indexOf方法

public int indexOf(Object o) {
	if (o == null) {
		for (int i = 0; i < size; i++)
			if (elementData[i]==null)
				return i;
	} else {
		for (int i = 0; i < size; i++)
			if (o.equals(elementData[i]))//多态
				return i;
	}
	return -1;
}

String类型:

ArrayList<String> names = new ArrayList<String>();
names.add("Tim");
System.out.println(names.contains("Tim"));

分析:
1、创建一个集合names,添加一个元素"Tim",然后判断"Tim"这个元素在不在集合names中
2、首先会调用contains方法,将"Tim"传为o,然后调用indexof方法,判断o不为null之后,将o与集合names中的元素对比,如果相同,返回true,不相同,返回false
3、String类型的对象,contains方法实质上调用的是String对象中的equals

包装类: 比如说Integer包装类

ArrayList<Integer> ages = new ArrayList<Integer>();
ages.add(18);
System.out.println(ages.contains(18));

分析:
1、创建一个集合ages,添加一个元素18,然后判断18这个元素在不在集合ages中
2、首先会调用contains方法,将18传为o,然后调用indexof方法,判断o不为null之后,将o与集合names中的元素对比,如果相同,返回true,不相同,返回false
3、包装类类型的对象,contains方法实质上调用的是包装类对象中的equals
自定义类类型:
自定义一个Student类:

public class Student {

	private String id;
	
	public Student(String id) {
		this.id = id;
	}
}
ArrayList<Student> students = new ArrayList<Student>();
students.add(new Student("111"));
System.out.println(students.contains(new Student("111")));

分析:
一、重写前
虽然id都是111,但是输出结果为false,因为比较的是地址是否相同,他们明显是两个对象,所以地址肯定不同,输出的就是false,就出现问题了,所以要重写equals方法
二、重写后

public class Student {

	private String id;
	
	public Student(String id) {
		this.id = id;
	}

	@Override
	public boolean equals(Object obj) {
		Student s = (Student)obj;
		return this.id.equals(s.id);
	}
}

首先会调用contains方法,将"111"传为o,然后调用indexof方法,判断o不为null之后,将o与集合students中的元素对比,这个时候使用的是重写后的equals,obj表示的是集合中的元素,首先要将它下转型为Student,然后将它与contains(new Student(“111”))这个new Student进行对比,如果相同,返回true,不相同,返回false
三、instanceof

public class Student {

	private String id;
	
	public Student(String id) {
		this.id = id;
	}

	@Override
	public boolean equals(Object obj) {
		if(obj instanceof Student) {
			Student s = (Student)obj;
			return this.id.equals(s.id);
		}
		return false;
	}
}

ArrayList<Object> list = new ArrayList<Object>();
list.add(new String());
System.out.println(list.contains(new Student("111")));

如果原本是Object类类型的,再用上面的就会出错,就需要添加instanceof,判断能否下转型,如果连下转型都无法实现,就不需要对比了,直接返回false就可以了

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值