我正在使用Global.asax通过Application_EndRequest事件在每个请求结束时执行日志记录。但是,我看到HTTPContext.Current.Items集合中存储的某些值的奇怪行为。
以下是可以为空的枚举的调试输出。您可以看到有一个值,但HasValue已解析为False?!
{System.Nullable(Of AreaNameEnum)}
HasValue: False
hasValue: False
Value: {System.InvalidOperationException}
value: ADMIN {0}
我猜测在请求生命周期中访问HTTPContext.Current已经太晚了 - 但它似乎有时会工作,有时却不行。任何人都可以更清楚地知道发生了什么事吗?
由于
答案 0 :(得分:4)
Nullable是一个结构,包含一个布尔值hasValue和一个T值,其中T是一个值类型。在这种情况下枚举。在这种情况下,枚举必须具有一些值,默认值为0,但是公共值会抛出异常,因为hasValue为false。
你所看到的是Nullable如何做它的内部结构。当hasValue为false时,您无法读取具有任何值的内部值字段中的任何内容。毕竟,如果value可以包含null,那么在这里使用Nullable将没有任何意义。