详述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就可以了

ArrayListcontains方法是通过调用参数对象的equals方法来判断是否包含该对象的。因此,如果要在ArrayList中判断自定义的,需要重写的equals方法。 例如,假设我们有一个自定义的Person: ``` public class Person { private String name; private int age; public Person(String name, int age) { this.name = name; this.age = age; } @Override public boolean equals(Object obj) { if (obj == null) { return false; } if (obj == this) { return true; } if (!(obj instanceof Person)) { return false; } Person otherPerson = (Person) obj; return this.name.equals(otherPerson.name) && this.age == otherPerson.age; } } ``` 在这个示例中,我们重写了equals方法,根据Person对象的name和age属性来判断两个对象是否相等。 使用ArrayListcontains方法判断该的示例代码如下: ``` Person person1 = new Person("Alice", 25); Person person2 = new Person("Bob", 30); ArrayList<Person> personList = new ArrayList<>(); personList.add(person1); personList.add(person2); Person person3 = new Person("Alice", 25); if (personList.contains(person3)) { System.out.println("person3 is in the list."); } else { System.out.println("person3 is not in the list."); } ``` 在这个示例中,我们创建了一个包含两个Person对象的ArrayList,并创建了一个新的Person对象person3,其name和age属性与person1相同。然后,我们使用ArrayListcontains方法来判断personList中是否包含person3,由于我们重写了Person的equals方法,因此该判断会返回true。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值