我正在使用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已经太晚了 – 但它似乎有时可行,有时却不行.任何人都可以更清楚地了解到底发生了什么?
谢谢
解决方法
Nullable是一个结构,包含一个布尔值hasValue和一个T值,其中T是一个值类型.在这种情况下,枚举.在这种情况下,枚举必须具有一些值,默认值为0,但是公共值会抛出异常,因为hasValue为false.
你所看到的是Nullable如何做它的内部结构.当hasValue为false时,您无法读取具有任何值的内部值字段中的任何内容.毕竟,如果value可以包含null,那么在这里使用Nullable将没有任何意义.