一个世界上最懒惰的程序员写的Cache也能让你的复杂计算程序(数据库程序)大大提高速度

来源:互联网 发布:java多线程的使用 编辑:程序博客网 时间:2024/06/04 17:41
仔细模拟一下你的数据库程序,你有没有发现在计算时(特别是多用户计算时)经常重复读取数据库数据?!这是数据库处理程序的性能的最主要的杀手。

有些人说在写程序之前应该把算法想好,使得数据记录成批地、一次性地读取。但是这实际上往往不可能,因为复杂的程序贴近逻辑流程才清晰可维护。更何况这也不能解决多用户访问的情况。最好,我们根本不用在写程序时去考虑数据是否会被重复读取从而改变程序流程,但是又能自然而然地防止重复读取数据库。当对计算过程进行优化,而又不想破坏逻辑清晰性的时候,当然就是要依靠简单的Cache —— 对象只要能够缓存几秒钟就好。

下面我这里写一个世界上最懒惰的程序员使用.net写的一个最简单的Cache,但是它往往可以让复杂的计算程序大大提高计算速度。


  1. using System;
  2. using System.Collections.Generic;
  3. namespace DomainBase
  4. {
  5. public class ObjectCache
  6. {
  7. //Dictionary<K,T> 会自动维护一个空链表来保存不用的单元。
  8. //这里,使用被缓存对象的“弱引用”,允许这些对象被垃圾回收。
  9. private Dictionary<string, WeakReference> Buffer = new Dictionary<string, WeakReference>();
  10. public object this[string key]
  11. {
  12. get
  13. {
  14. WeakReference ret;
  15. if (Buffer.TryGetValue(key, out ret) && ret.IsAlive)
  16. return ret.Target;
  17. else
  18. return null;
  19. }
  20. set
  21. {
  22. WeakReference ret;
  23. if (Buffer.TryGetValue(key, out ret))
  24. ret.Target = value;
  25. else
  26. Buffer.Add(key, new WeakReference(value));
  27. }
  28. }
  29. public void Remove(string key)
  30. {
  31. Buffer.Remove(key);
  32. }
  33. }
  34. }




这就是最简单的Cache。例如:

public Class User
{
    static ObjectCache Buffer=new ObjectCache();

    public static GetUser(string id)
    {
      User ret=Buffer[id];
      if(ret==null)
      {
            ret=读取数据库产生User对象(id);
            Buffer[id]=ret;
      }
      return ret;
    }
.....

这里,在一个Dictionary <K,T>结构字典中保存了对象的key以及对象的“弱引用”。这样,当内存不足时GC会照样去释放被缓存的对象。当我们需要将对象在几秒钟内进行缓存时,使用这个最简单的Cache很有用。

.netframework中有非常多非常多的东西需要程序员去了解,不要仅仅抱着那些空洞、不实惠的“放之四海而皆准”的大部头的著作,有时间要多读一些实际地分析 .net framework系统本身的方面的资料。在每一个技术中都可以找对一两个细节,这个细节就像掌握DNA技术一样能够让你不但扩展原理而且通过动手能力得到巨大实惠。