假设我有以下界面:
public interface IApiOutputCache
{
Task RemoveStartsWithAsync(string key);
Task<T> Get<T>(string key) where T : class;
Task RemoveAsync(string key);
Task<bool> ContainsAsync(string key);
Task Add(string key, object o, DateTimeOffset expiration, params string[] dependsOnKeys);
Task<IEnumerable<string>> GetAllKeys();
}
我可以实现不同的缓存提供程序。我为两个不同的缓存实现了两次:
a)天蓝色的红色 b)内存缓存
对于azure redis,这非常合适,因为StackExchange.Redis为我提供了所有的异步方法,所以我可以保持完全异步。
现在我为内存缓存实现了另一个,它不为我提供异步api。
现在实现此界面的最佳实践是什么?
按原样实现,但只是做一切同步?将内部调用变为Task.Run
(对于我认为的快速mem缓存调用不是一个好主意。)
答案 0 :(得分:8)
忘记Task.Run
,无需向ThreadPool
卸载任何内容。
同步实施所有内容,并在返回值时返回已完成的Task
Task.FromResult
,而不返回Task.CompletedTask
:
Task<T> GetAsync<T>(string key)
{
T result = Get(key);
return Task.FromResult(result);
}
Task RemoveAsync(string key)
{
Remove(key);
return Task.CompletedTask;
}
甚至更好,因为它是一个缓存,您可以自己缓存任务而不是结果,并且每次都返回相同的任务对象。