7

NRE

为什么 VS 2012 将 Type 变量显示为 NullReferenceException,而它也显示为value = "Retailer".

在此处输入图像描述

我有一个新生儿,我正在努力限制睡眠,所以如果我在这里遗漏了一些明显的东西,我深表歉意。LoggedInUser.Employer 对象已被实例化,这条线在 1/2 的时间内工作正常。但随后它开始破裂。不确定这是否有帮助 - 需要睡觉......

 private string _type;
    public string Type
    {
        get { return _type; }
        set
        {
            if (value != null)
            {
                TypeEnum = (Constants.BusinessType)Enum.Parse(typeof(Constants.BusinessType), value, true);
                _type = value;
            }
        }
    }

在此处输入图像描述 我开始怀疑这是否是一个跨线程问题...

在此处输入图像描述

4

3 回答 3

2

ExecutionContext负责存储实例的 ASP.NETHttpContext.Current不会自然地“流向”其他线程。从您的错误堆栈跟踪来看,您正在使用 ASP.NET MVC,这是一个抽象出HttpContext. 您可能来自 WebForms 背景,直接使用它很常见?

同步上下文

这篇文章提供的细节比我能合理介绍的要多得多。不过,与您的情况最相关的一些要点是:

“ExecutionContext 都是关于‘环境’信息的,这意味着它存储与当前环境或你正在运行的‘上下文’相关的数据。”

这种“环境”信息是……HttpContext.Current及其各种属性(包括Session)。

“这意味着我们用来控制执行细节的环境上下文不再可行,因为 TLS 不会在这些异步点之间“流动”。”

TLS 是线程本地存储(HttpContext.Current等)。简而言之,async = 可能会丢失HttpContext.Current

MVC 方式

还记得我说过 MVC 主要是抽象的HttpContext吗?

SessionController.Session中。(很抱歉,我尚未在异步控制器操作中对此进行测试,因此目前无法验证它是否适合您的需求,或者您是否需要额外的工作才能使其配合。)

RequestController.Request中

UserController.User中

还有其他...检查出来

会话替代方案?

你考虑过替代品吗?您不必走太远就能找到暗示 Session + ASP.NET MVC 是个坏主意的文章。我不会对它是否是“坏事”这样笼统的东西进行权衡,但看看你的例子,在我看来你正在处理用户个人资料数据,而不是“会话”数据。

Session 并不是缓存用户配置文件信息的正确位置。就此而言,缓存它是否合适?会话期间用户配置文件是否会更改?如果他们自己更改,您会重置会话吗?如果单独的管理员用户在登录时更改了他们的个人资料怎么办?

探索替代方案超出了问题的范围,但请注意您可能在这里尝试解决错误的问题。

于 2013-02-19T21:23:58.443 回答
1

String.IsNullOrEmpty 不会在字符串上引发此异常,即使它为 null,所以 Type 属性不是问题。LoggedInUser 在没有错误之前使用了 2 行,因此将 Employer 属性作为罪魁祸首(除非 String 不是内置的 String)。

您可以在其上添加对 null 的检查以确认:

if (LoggedInUser.Employer != null) 
{
    if (String.IsNullOrEmpty(LoggedInUser.Employer.Type))
    {
        ...  
    }
}
else
{
    // debug output
}

假设 Employer 为 null,您需要在此处提供该属性定义。因为您只有在多个用户登录时才能看到这一点,所以我怀疑它不应该出现在某个地方的静态声明。

于 2013-02-18T20:29:00.473 回答
0

我的猜测是您在某处声明了一个名为“String”的字段 - 尝试使用小写的“string.IsNullOrEmpty”或“System.String.IsNullOrEmpty”作为一个......

于 2013-02-18T20:03:09.357 回答