9

我编写了一个简单的 SessionItem 管理类来处理所有那些讨厌的空检查,如果不存在则插入一个默认值。这是我的 GetItem 方法:

public static T GetItem<T>(string key, Func<T> defaultValue)
{
    if (HttpContext.Current.Session[key] == null)
    {
        HttpContext.Current.Session[key] = defaultValue.Invoke();
    }
    return (T)HttpContext.Current.Session[key];
}

现在,我如何实际使用它,将 Func<T> 作为内联方法参数传递?

4

3 回答 3

16

由于这是一个函数,因此 lambda 将是最简单的方法:

Foo foo = GetItem<Foo>("abc", () => new Foo("blah"));

其中 [new Foo("blah")] 是默认调用的函数。

您还可以简化为:

return ((T)HttpContext.Current.Session[key]) ?? defaultValue();

在哪里 ??是 null 合并运算符 - 如果第一个 arg 不为 null,则返回它;否则评估并返回右手(因此除非项目为空,否则不会调用 defaultValue() )。

最后,如果您只想使用默认构造函数,那么您可以添加一个“new()”约束:

public static T GetItem<T>(string key)
    where T : new()
{
    return ((T)HttpContext.Current.Session[key]) ?? new T();
}

这仍然是懒惰的 - new() 仅在项目为空时使用。

于 2008-10-01T09:08:07.717 回答
2

为什么不直接传递默认值呢?函子有什么用?

顺便说一句,defaultValue.Invoke()相当冗长。也可以只写defaultValue()

于 2008-10-01T09:03:43.297 回答
1
var log = SessionItem.GetItem("logger", () => NullLog.Instance)

请注意,通常您可以在 GetItem{T} 调用中跳过 {T} 规范(如果 Func{T} 返回相同类型的对象)

于 2008-10-01T09:08:27.093 回答