重要的先说: 可以通过重写A类的equals方法来自定义ArrayList<>中的contains比较逻辑
// 具体为什么 我们来看看源码
// 最后一直往下找的时候会找到这段代码...
int indexOfRange(Object o, int start, int end) {
Object[] es = elementData;
if (o == null) {
for (int i = start; i < end; i++) {
if (es[i] == null) {
return i;
}
}
} else {
for (int i = start; i < end; i++) {
if (o.equals(es[i])) {
return i;
}
}
}
return -1;
}
注意看其中比较醒目的o.equals(es[i]),说明这个方法最后是调用了我们的equals函数
因此想要自定义比较逻辑,我们只需要重写equals函数即可
另: 可能有部分人是想用 contains 检验下是否有这个元素,再 remove;但如果我们看看remove的源码就发现不必这样了
public boolean remove(Object o) {
final Object[] es = elementData;
final int size = this.size;
int i = 0;
found: {
if (o == null) {
//空引用特殊情况判断
for (; i < size; i++)
if (es[i] == null)
break found;
} else {
// 遍历找是否有该元素
for (; i < size; i++)
if (o.equals(es[i]))
break found;
}
// 遍历后发现无对象匹配,不执行删除
return false;
}
// 有对象匹配,进行删除
fastRemove(es, i);
return true;
}