Java:ArrayList中的contains方法

我们先看一下调用的效果:

import java.util.ArrayList;
piblic class Test {
	public static void main(String [] args){
		ArrayList<String> list =new ArrayList<String>();//jdk7.0及以上版本,可以不加new后的泛型类型
		list.add("tom");
		String name="tom";
		System.out.println(list.contains(name));
	}
}
/*运行结果
true*/

那么,contains方法是如何实现判断的呢:

public boolean contains(Object o) {//contains方法传入参数为对象o,即此时o为name,所以name为一个上转型对象
	return indexOf(o) >= 0;//调用下面indexOf方法,并判断是否小于零,返回布尔类型的结果
}
 
public int indexOf(Object o) {//contains中的o传入到这里,name依旧为上转型对象
	if (o == null) {//o不为null,执行else
		for (int i = 0; i < size; i++)
			if (elementData[i]==null)
				return i;
	} else {
		for (int i = 0; i < size; i++)//for循环遍历list中每一个元素;其中size为全局变量,this.size:表示list的元素个数;
		if (o.equals(elementData[i]))//①
			return i;//返回找到相同时,元素的位置
	}
	return -1;
}

①此时o调用equals方法,由于o为String类对象,o为上转型对象,所以此时出现多态性,o调用String类中重写过的equals方法:对比调用对象和传入对象地址中存的字符串是否相同,如果是,返回true,如果不是返回false。elementData为存着list元素的数组,所以这个判断语句的作用就是,当发现list已有的元素中,有想要的寻找的元素,就进入if分支。

  • 此时,我们改变传入对象的值进行分析:
//调用
import java.util.ArrayList;
piblic class Test {
	public static void main(String [] args){
		ArrayList<String> list =new ArrayList();
		list.add("tom");
		String name=null;
		System.out.println(list.contains(name));
	 }
}
/*运行结果
false*/
//进行分析
public boolean contains(Object o) {//contains方法传入参数为对象o,即此时o为name,所以name为一个上转型对象
	return indexOf(o) >= 0;//调用下面indexOf方法,并判断是否小于零,返回布尔类型的结果
}

public int indexOf(Object o) {//contains中的o传入到这里,name依旧为上转型对象
	if (o == null) {//o为null,执行if下true分支
		for (int i = 0; i < size; i++)//for循环遍历list中每一个元素
		if (elementData[i]==null)//判断是否有元素存值为空
			return i;//返回找到相同时,元素的位置
	} else {
		for (int i = 0; i < size; i++)
		if (o.equals(elementData[i]))
		return i;
	}
	return -1;
}
  • 然后,我们改变传入的对象的类型进行分析
//调用
import java.util.ArrayList;
piblic class Test {
	public static void main(String [] args){
		ArrayList<String> list =new ArrayList();
		list.add("tom");
		Test test=new Test;
		String name="tom";
		System.out.println(list.contains(name));
	}
}
/*运行结果
false*/
//进行分析
public boolean contains(Object o) {//contains方法传入参数为对象o,即此时o为test,所以test为一个上转型对象
	return indexOf(o) >= 0;//调用下面indexOf方法,并判断是否小于零,返回布尔类型的结果
}
 
public int indexOf(Object o) {//contains中的o传入到这里,test依旧为上转型对象
	if (o == null) {//o不为null
		for (int i = 0; i < size; i++)
		if (elementData[i]==null)
			return i;
	} else {
		for (int i = 0; i < size; i++)//for循环遍历list中每一个元素
		if (o.equals(elementData[i]))//②
		return i;
	}
	return -1;
}

②此时test为上转型对象。但是由于test并没有重写equals方法,所以调用的为原来的Obj类中的equals方法:对比调用对象和传入参数(即list中元素)的地址是否相同。Test对象和String类对象没有关系所以显然地址不一样。

  • 那么,如果元素为对象,我们想通过某个属性来判断是否存在时,该怎么做呢?
    方法:通过在该对象类中,重写合适的equals方法

  • 例,我们想存入学生对象,并通过唯一id判断学生是否已存在

//Student类
public class Student{
	String id;
	String name;
	public  Student() {
	}
	public Student (String id){
		this.id=id;
	}
	@Override
	public boolean equals(Object obj) {//重写Object类中的equals方法
		Student student =(Student)obj;//对象下转型,因为调用contains方法的为元素,本例中则为Student类的对象,故obj为上转型对象,要使用子类新的成员变量,则需要下转型
		return this.id.equals(student.id);//改写为id调用的equals方法,id为String类,故调用String中的equals方法,比较字符串是否一致,达到比较id内容的目的
	}
}
//主函数
public class Test{
	public static void main(String [] args){
	ArrayList<Student> list = new ArrayList();
	Student stu1=new Student("12345");
	Student stu2=new Student("12345");
	list.add(stu1);
	System.out,println(list.contains(stu2));
	}
}
//进行分析
public boolean contains(Object o) {//contains方法传入参数为对象o,即此时o为stu2,所以o为一个上转型对象
	return indexOf(o) >= 0;//调用下面indexOf方法,并判断是否小于零,返回布尔类型的结果
}
 
public int indexOf(Object o) {//contains中的o传入到这里,依旧为上转型对象
	if (o == null) {//o不为null
		for (int i = 0; i < size; i++)
		if (elementData[i]==null)
			return i;
	} else {
		for (int i = 0; i < size; i++)//for循环遍历list中每一个元素
		if (o.equals(elementData[i]))//此处出现多态,stu2调用Student类中重写过的equals方法,与list中每个学生对象的id进行比对
		return i;
	}
	return -1;
}

优化:

//Student类
public class Student{
	String id;
	String name;
	public  Students() {
	}
	public Students (String id){
		this.id=id;
	}
	@Override
	public boolean equals(Object obj) {//重写Object类中的equals方法
		if(obj instanceof Student){//判断对比对象是否能下转型,避免发生异常
			Student student =(Student)obj;
			return this.id.equals(student.id);
		}
		return false;
	}
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: JavaArrayList类提供了contains()方法,用于判断列表是否包含指定的元素。该方法返回一个布尔值,如果列表包含指定元素,则返回true,否则返回false。 使用方法如下: 1. 创建一个ArrayList对象,例如: ArrayList<String> list = new ArrayList<String>(); 2. 向列表添加元素,例如: list.add("apple"); list.add("banana"); list.add("orange"); 3. 使用contains()方法判断列表是否包含指定元素,例如: boolean result = list.contains("banana"); if (result) { System.out.println("列表包含banana"); } else { System.out.println("列表不包含banana"); } 输出结果为: 列表包含banana 注意:contains()方法判断元素是否相等是通过equals()方法实现的,因此如果列表包含自定义对象,需要重写equals()方法。 ### 回答2: JavaArrayList类是一种可变数组,支持动态添加、删除和修改元素,并且内置了许多实用的方法来操作数组。其contains()方法ArrayList非常常用的方法之一。 contains()方法用于判断ArrayList是否包含某个元素。它的语法如下: ``` public boolean contains(Object o) ``` 其Object o是需要判断的元素。如果ArrayList包含o,那么会返回true,否则返回false。 下面是一个简单的例子: ``` import java.util.ArrayList; public class Main { public static void main(String[] args) { ArrayList<String> list = new ArrayList<String>(); list.add("apple"); list.add("banana"); list.add("orange"); System.out.println("List contains apple: " + list.contains("apple")); System.out.println("List contains kiwi: " + list.contains("kiwi")); } } ``` 运行结果: ``` List contains apple: true List contains kiwi: false ``` 从上面的例子可以看出,contains()方法首先需要ArrayList包含元素,然后才能判断是否相等。在判断相等时,contains()方法会自动使用equals()方法来进行比较。 可以将contains()方法应用于其他类型的ArrayList,如Integer、Double等。 但是需要注意,对于自定义对象,需要正确实现equals()方法。 在实际开发contains()方法可以用来判断ArrayList是否包含指定元素,从而避免重复元素的添加,同时也可以应用于集合查找等问题。 ### 回答3: JavaArrayList是一个动态数组,它可以存储任意类型的对象。contains方法ArrayList提供的一个常用方法,它用于判断指定元素是否包含在ArrayListcontains方法的返回值为boolean类型,如果ArrayList包含指定元素,返回true,否则返回false。contains方法的实现原理是遍历整个ArrayList,逐个比较元素是否相等,因此其时间复杂度为O(n),不适合对大规模数据进行查找。 contains方法可以用于判断对象是否存在于ArrayList,其比较过程是使用对象的equals方法来进行比较。如果需要自定义对象比较的方式,可以重写对象的equals方法。 需要注意的是,如果ArrayList存储的是基本数据类型,如int、double等,contains方法将无法进行比较。此时可以使用包装类,如Integer、Double等来存储基本数据类型,然后使用contains方法进行比较。 同时,如果ArrayList存储的对象是可变对象,如List或Map等,contains方法比较的是对象的引用,而不是对象的内容。此时需要重写对象的equals方法来进行比较。 最后,需要特别注意的是,在使用contains方法时需要确保对象正确实现了equals方法和hashCode方法,否则可能会出现意想不到的结果,例如当对象作为HashMap的key时,无法正常获取对应的value。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值