【C#】.net core2.1,在实体类写了个非常经典的无限循环错误

169 阅读1分钟

我正在参加「掘金·启航计划」

遇到一个非常有趣的bug,使用VS2017调试运行.net core2.1 MVC项目时,程序本身运行的好好的,突然启动起来就报错
不得不说,编码细节很重要

 报错如下

  • 启动时提示 20220611101227.png

  • 页面报错提示 20220611101222.png

2、原因分析

1)在报错前,什么代码都未修改,然后网上找解决方案,对于这类问题都是千篇一律,基本都是在IIS环境出现,后来找到一个关键点,重定向。

2)然后从程序断点调式,确认Startup启动文件方法是否可以执行,确认可执行,初步排查应该不是这个环境出错

3)然后再到重定向里排查,因为MVC加了一个权限验证,未登录Redirect,发现公共控制器是可以进来

4)然后逐个排查分析,结果是在公共控制器的finally代码发生异常,注释掉代码,程序可运行

5)再排查到是运行如下代码直接自动关闭运行

Task.Factory.StartNew

分析来分析去,运行到这个代码又没有报错,已经加了try_catch,没有跳到catch

6)最后一拍大腿,天空飘来两个字WC,想起来了,再实体类里嵌套添加了实体类,写了一个非常经典的循环逻辑错误

public class OneEntity
{
    public class int id {get;set;}
    public class string name {get;set;}
}
public class TwoEntity : OneEntity
{
    public PageEntity one
    {
        get
        {
            OneEntity oneEntity = new OneEntity();
            oneEntity.page_index = page_index;
            oneEntity.page_size = page_size;

            return one; //此处是错误点,返回了自己本身,这里应该返回oneEntity
        }
    }
}

3、真正原因

编码逻辑问题,写了个无限循环,自己返回自己本身,所以,程序检查到无限循环后自动报错了