因此,我们有一个WCF服务,可以为客户端提供一些对象.我们的wcf服务从数据访问层(DAL)获取数据. DAL从API获取数据,并将其格式化为我们可以使用的对象.对于大多数对象来说,这很好.但是我们还需要API中的对象列表,并且这...
因此,我们有一个WCF服务,可以为客户端提供一些对象.我们的wcf服务从数据访问层(DAL)获取数据. DAL从API获取数据,并将其格式化为我们可以使用的对象.对于大多数对象来说,这很好.
但是我们还需要API中的对象列表,并且这些对象不会更改.针对API的查询需要15到20秒.长时间对同一数据多次运行此查询的方法.因此,我们想将列表存储在内存中.因为DBA不是我们最好的朋友,所以SQLite或SQL CE也不是一个选择.
现在我们有了类似的东西,第一次加载组时,我们将它们存储在私有静态变量中.这是做这样事情的正确方法,还是有更好的方法?
public static class GroupStore
{
private static DTO.Group[] _groups;
public static DTO.Group[] GetAll()
{
if (_groups == null)
{
var dal = PluginHandler.Instance.GetPlugin();
_groups = dal.GetAll();
}
return _groups;
}
}
解决方法:
如果您使用的是.NET4,则可以使用Lazy< T>类.它是线程安全的,并为您包装了延迟加载.
代码变得更加干净:
public static class GroupStore
{
private static Lazy<DTO.Group[]> _groups = new Lazy<DTO.Group[]>(GetAll);
public static DTO.Group[] Groups { get { return _groups.Value; } }
private static DTO.Group[] GetAll()
{
var dal = PluginHandler.Instance.GetPlugin();
return dal.GetAll();
}
}
更新资料
您在评论中链接的答案是可以的.但是IsValueCreated使用锁定没有理由(因为列表可能在检查和下一次访问之间发生了变化).
如果调用“ ToString” get,我也不会创建该值.
更干净的解决方案:
public sealed class Lazy<T> where T : class
{
private readonly object _syncRoot = new object();
private readonly Func<T> _factory;
private T _value;
public Lazy(Func<T> factory)
{
if (factory == null) throw new ArgumentNullException("factory");
_factory = factory;
}
public T Value
{
get
{
if (_value == null)
{
lock (_syncRoot)
{
if (_value == null)
{
_value = _factory();
}
}
}
return _value;
}
}
public override string ToString()
{
return _value == null ? "Not created" : _value.ToString();
}
}
本文标题为:c#-在内存中存储数组的最佳实践
基础教程推荐
- C#使用NPOI对Excel数据进行导入导出 2023-06-14
- 关于C#继承的简单应用代码分析 2023-04-15
- c# 实现计时器功能 2023-03-28
- C#关键字Check简单介绍 2023-05-30
- C#实现语音播报功能 2023-05-26
- Unity Shader模拟玻璃效果 2023-02-16
- C# windows服务定时处理/例每天凌晨1点处理数据 2023-11-28
- C# 获取指定QQ头像绘制圆形头像框GDI(Graphics)的方法 2023-05-06
- .net core Docker Compose启动问题: Debugging Error, The program to be debug con not be found in the conta 2023-09-28
- C#中多态性的实现 2023-02-08