广告位联系
返回顶部
分享到

使用lombok的@Data会导致栈溢出StackOverflowError问题

java 来源:互联网 作者:佚名 发布时间:2022-11-20 22:22:02 人浏览
摘要

问题复现 两个类,有循环引用: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 @Data public class Obj1 { private String a; private String b; private Obj2 obj2; } @Data public class Obj2 { private String a; pri

问题复现

两个类,有循环引用:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

@Data

public class Obj1 {

    private String a;

    private String b;

    private Obj2 obj2;

}

 

@Data

public class Obj2 {

    private String a;

    private String b;

    private Obj1 obj1;

}

 

public class Test {

    public static void main(String[] args) {

        Obj1 obj1 = new Obj1();

        Obj2 obj2 = new Obj2();

 

        obj1.setObj2(obj2);

        obj2.setObj1(obj1);

 

        System.out.println(obj1);

    }

}

执行上述程序,结果出现栈溢出:

原因分析

首先出现上述问题的场景是出现了循环依赖。

@Data注解在什么情况下可能导致StackOverflowError情况呢?原因在于@Data重写了hashCode()方法。

我们看一下两个类的hashCode方法:

Obj1的hashCode方法

1

2

3

4

5

6

7

8

9

10

11

public int hashCode() {

    int PRIME = true;

    int result = 1;

    Object $a = this.getA();

    int result = result * 59 + ($a == null ? 43 : $a.hashCode());

    Object $b = this.getB();

    result = result * 59 + ($b == null ? 43 : $b.hashCode());

    Object $obj2 = this.getObj2();

    result = result * 59 + ($obj2 == null ? 43 : $obj2.hashCode());

    return result;

}

Obj2的hashCode方法

1

2

3

4

5

6

7

8

9

10

11

public int hashCode() {

    int PRIME = true;

    int result = 1;

    Object $a = this.getA();

    int result = result * 59 + ($a == null ? 43 : $a.hashCode());

    Object $b = this.getB();

    result = result * 59 + ($b == null ? 43 : $b.hashCode());

    Object $obj1 = this.getObj1();

    result = result * 59 + ($obj1 == null ? 43 : $obj1.hashCode());

    return result;

}

可以看到,计算obj1的hashcode,需要去获取obj2的hashcode, 而计算obj2的hashcode ,又要去获取obj1的hashcode。所以出现了死循环。

解决方案

不要使用@data, 使用@Getter, @Setter。


版权声明 : 本文内容来源于互联网或用户自行发布贡献,该文观点仅代表原作者本人。本站仅提供信息存储空间服务和不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权, 违法违规的内容, 请发送邮件至2530232025#qq.cn(#换@)举报,一经查实,本站将立刻删除。

您可能感兴趣的文章 :

原文链接 : https://it007.blog.csdn.net/article/details/111993916
    Tag :
相关文章
  • 本站所有内容来源于互联网或用户自行发布,本站仅提供信息存储空间服务,不拥有版权,不承担法律责任。如有侵犯您的权益,请您联系站长处理!
  • Copyright © 2017-2022 F11.CN All Rights Reserved. F11站长开发者网 版权所有 | 苏ICP备2022031554号-1 | 51LA统计