自定义对象ArrayList的indexOf用法

今天做项目的时候碰到一个功能需要使用ArrayList的indexOf方法,ArrayList中存放的是一组自定义的Notice对象,需要知道当前的一个Notice对象(此对象通过另外一个方法查询出)在这个ArrayList中的位置,查了API,用indexOf方法,可是debug的时候却发现返回值是-1,而这个Notice对象确实存在list中并且两个对象内容完全相同。于是写了一个demo来验证这个问题。


测试类1:TestClass。2个String类型的属性name,id

class TestClass {
	public TestClass(String name, String id) {
		this.name = name;
		this.id = id;
	}
	
	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}

	public String getId() {
		return id;
	}

	public void setId(String id) {
		this.id = id;
	}

	String  name;
	String id;
}
测试代码:

package test.test;

import java.util.ArrayList;
import java.util.List;

public class TestIndexof {
	public static void main(String[] args) {
		List<TestClass> list = new ArrayList<TestClass>();
		TestClass c1 = new TestClass("first", "1");
		list.add(c1);
		TestClass c2 = new TestClass("second", "2");
		list.add(c2);
		TestClass c3 = new TestClass("third", "3");
		list.add(c3);
		TestClass c4 = new TestClass("third", "3");
		System.out.println("Index:"+list.indexOf(c3));
		System.out.println("Index:"+list.indexOf(c4));
	}
}

class TestClass {
	public TestClass(String name, String id) {
		this.name = name;
		this.id = id;
	}
	
	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}

	public String getId() {
		return id;
	}

	public void setId(String id) {
		this.id = id;
	}

	String  name;
	String id;
}

输出结果:

Index:2
Index:-1

C3对象返回索引是2,C4为-1,而这2个对象的内容都是一样的。注意到C3是通过add方法加入list的对象,而c4是new出来的。看下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;
    }

由于TestClass类没有重写euqals方法,这里使用了Object的equals方法,由于传入的C3的内存地址和list中的C3内存地址是一样的,所以返回正确的结果,而C4是new出来的,内存中的地址和list中的C3已经不一样了,尽管他们的内容是完全一样的,所以返回-1。

要解决这个问题可以重写传入indexOf的对象的equals方法。由于TestClass对象id是不重复的,所以用比较id的方法来重写equals方法:

class TestClass {
	public TestClass(String name, String id) {
		this.name = name;
		this.id = id;
	}
	
	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}

	public String getId() {
		return id;
	}

	public void setId(String id) {
		this.id = id;
	}

	@Override
	public boolean equals(Object obj) {
		if (obj instanceof TestClass) {
			if (this.getId().equals(((TestClass) obj).getId())) {
				return true;
			}
			else {
				return false;
			}
		}
		return false;
	}

	String  name;
	String id;
}

改写TestClass类后,再次运行测试代码,结果如下:

Index:2
Index:2

  • 12
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
自定义类的indexOf方法可以根据自己的需求来实现。通常情况下,我们可以通过遍历数组中的元素,逐个比较元素与目标对象是否相等,如果相等则返回该元素的下标,如果遍历完整个数组都没有找到相等的元素,则返回-1。以下是一个示例代码: ```java public class CustomArray { private Object\[\] elements; private int size; // 构造方法和其他方法省略 public int indexOf(Object target) { for (int i = 0; i < size; i++) { if (target.equals(elements\[i\])) { return i; } } return -1; } } ``` 在这个示例中,我们通过遍历数组中的元素,使用equals方法来比较目标对象与数组元素是否相等。如果相等,则返回该元素的下标。如果遍历完整个数组都没有找到相等的元素,则返回-1。请注意,这里使用了equals方法而不是"=="来比较对象的相等性,因为equals方法可以根据自定义类的实现来判断对象是否相等。 #### 引用[.reference_title] - *1* *2* [Array 的 indexOf方法](https://blog.csdn.net/wdadadadada123/article/details/90702180)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [自定义对象ArrayListindexOf用法](https://blog.csdn.net/oHeHeHou/article/details/8456511)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值