直接比较两个对象是否相等返回false和List中判断是否包含某个对象的问题

定义如下类

class GG{

private String name;
public GG(String name){
this.name=name;
}
@Override
public int hashCode() {
final int prime = 31;
int result = 1;
result = prime * result + ((name == null) ? 0 : name.hashCode());
return result;

}

}

再定义两个对象

GG g1=new GG("1");

GG g2=new GG("2");

如果直接进行比较:g1===g2将会返回false因为这样比较的是二者的引用。

这里我们现在需要重写equals 和 hashCode 方法;


class GG{
private String name;
public GG(String name){
this.name=name;
}
@Override
public int hashCode() {
final int prime = 31;
int result = 1;
result = prime * result + ((name == null) ? 0 : name.hashCode());
return result;
}
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (getClass() != obj.getClass())
return false;
GG other = (GG) obj;
if (name == null) {
if (other.name != null)
return false;
} else if (!name.equals(other.name))
return false;
return true;
}
}

通常我们所用的String类型不用重写,可以直接用。

这两个方法可以通过myEclipse自动生成

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以使用递归方式比较两个List集合对象属性值是否相等,如果List包含List,则递归比较。下面是一个示例代码: ```java public class CompareList { public static boolean compare(List<?> list1, List<?> list2) { if (list1 == null && list2 == null) { // 如果两个List都为null,则认为它们相等 return true; } if (list1 == null || list2 == null) { // 如果其一个List为null,则认为它们不相等 return false; } if (list1.size() != list2.size()) { // 如果两个List的长度不相等,则认为它们不相等 return false; } for (int i = 0; i < list1.size(); i++) { Object obj1 = list1.get(i); Object obj2 = list2.get(i); if (obj1 == null && obj2 == null) { // 如果两个对象都为null,则认为它们相等 continue; } if (obj1 == null || obj2 == null) { // 如果其一个对象为null,则认为它们不相等 return false; } if (!obj1.getClass().equals(obj2.getClass())) { // 如果两个对象的类型不相同,则认为它们不相等 return false; } if (obj1 instanceof List && obj2 instanceof List) { // 如果两个对象都是List类型,则递归比较 if (!compare((List<?>) obj1, (List<?>) obj2)) { return false; } } else if (!obj1.equals(obj2)) { // 如果两个对象相等,则认为它们不相等 return false; } } return true; } } ``` 使用示例: ```java List<Object> list1 = new ArrayList<>(); list1.add("a"); list1.add(1); List<Object> sublist1 = new ArrayList<>(); sublist1.add("b"); sublist1.add(2); list1.add(sublist1); List<Object> list2 = new ArrayList<>(); list2.add("a"); list2.add(1); List<Object> sublist2 = new ArrayList<>(); sublist2.add("b"); sublist2.add(2); list2.add(sublist2); System.out.println(CompareList.compare(list1, list2)); // 输出true ```

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值