我编写了一个简单的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&lt; T&gt;作为内联方法参数?

有帮助吗?

解决方案

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

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

其中[new Foo(“blah”)]是作为默认调用的func。

您还可以简化为:

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

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

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

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

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

其他提示

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

顺便说一句, defaultValue.Invoke()非常详细。也可以只写 defaultValue()

var log = SessionItem.GetItem("logger", () => NullLog.Instance)

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

许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top