因此,我们有一个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#调用SQL Server中有参数的存储过程 2023-05-25
- c# – 在客户端控制台应用程序中保存SQL Server连接字符串的位置? 2023-11-14
- 深入理解C#中常见的委托 2023-04-22
- C# 通过反射初探ORM框架的实现原理(详解) 2022-12-01
- 浅谈static a[n*m]={0};中static的作用 2022-11-05
- C# Winform中如何绘制动画示例详解 2023-02-17
- 详解c#与js的rsa加密互通 2023-04-10
- 深入理解C#委托delegate的使用 2023-06-27
- .Net Core 路由处理 2023-09-27
- C#winform中数据库绑定DataGrid的实现 2023-06-08