新书推介:《语义网技术体系》
作者:瞿裕忠,胡伟,程龚
   XML论坛     W3CHINA.ORG讨论区     计算机科学论坛     SOAChina论坛     Blog     开放翻译计划     新浪微博  
 
  • 首页
  • 登录
  • 注册
  • 软件下载
  • 资料下载
  • 核心成员
  • 帮助
  •   Add to Google

    >> 软件工程、需求工程、系统工程,UML、MDA、模型驱动开发,面向对象软件工程、面向目标软件成功、面向场景的设计、敏捷
    [返回] 计算机科学论坛计算机技术与应用『 软件工程论坛 』 → 空间换时间,Memoization,单件模式,备忘录模式,之间的关系。[原创] 查看新帖用户列表

      发表一个新主题  发表一个新投票  回复主题  (订阅本版) 您是本帖的第 12744 个阅读者浏览上一篇主题  刷新本主题   树形显示贴子 浏览下一篇主题
     * 贴子主题: 空间换时间,Memoization,单件模式,备忘录模式,之间的关系。[原创] 举报  打印  推荐  IE收藏夹 
       本主题类别:     
     pennyliang 帅哥哟,离线,有人找我吗?白羊座1979-4-7
      
      
      威望:8
      等级:大二期末(C++考了100分!)
      文章:266
      积分:1911
      门派:Lilybbs.net
      注册:2005/3/11

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给pennyliang发送一个短消息 把pennyliang加入好友 查看pennyliang的个人资料 搜索pennyliang在『 软件工程论坛 』 的所有贴子 引用回复这个贴子 回复这个贴子 查看pennyliang的博客楼主
    发贴心情 空间换时间,Memoization,单件模式,备忘录模式,之间的关系。[原创]

    在设计模式中,名字的命名一般都和具体应用有关,这里我们从单件模式,和备忘录模式挖掘一些深层次的东西。

    首先来看单件模式,本质上,它是构造一次,每次要用到的时候不需要重复构造,直接取出即可,我们不妨把构造变成计算,那么就是,计算一次,然后存储,不在重复计算。

    在看备忘录模式,每个对象都含有内部状态,但是对象的状态都在不断变化,如何保留这些变化,备忘录模式协助我们保留用户的状态,那么本质上也是,计算一次,然后存储,下次需要的时候直接取出。不需要redo前面的计算。比如一个对象这样变迁

    object[state1] - event1->object[state2]- event2->.......object[statei]

    如果我们要得到object  在状态i是的数据,那么有两个办法,一个是记录全部的event,然后从object[state1]开始redo,另一个办法就是存储全部的state,以备查询。

    从上可知,都存在以下抽象的操作

    1)compute

    2)save

    3)if (saved) get else compute then save

    这种在算法中称作Memoization algorithm, 在动态规划中应用为重叠子结构。方法与之类似,不再多讲,那么他们

    的本质是什么呢?这样做的好处是什么能,存储计算的好处是什么呢?

    这来自于一个很朴素的原理,就是时间和空间的问题,这个所有学习计算机的人都知道,如果一种计算被经常执行

    那么这种计算结果被存储的结果,就把计算的时间变为了查表的时间,拿单件来说,如果一个对象,我们经常需要

    它,而且不希望每次需要的时候构造他,用完了就析构他,希望保留一份实例,那么就是空间换时间的经典例子,

    可能有人会说我故意遗漏了唯一性的这个属性,单件的唯一性就是集合的唯一性,一个计算如果被保留了,那么就

    不需要再次被计算了,计算仅唯一的计算一次,空间中也仅保留唯一的计算结果。

       最后,我不禁得到这样一个结论,一切皆有联系,最终的原理其实都是朴实无华的.

    原创于:
    http://blog.csdn.net/pennyliang/archive/2007/01/06/1475741.aspx


       收藏   分享  
    顶(0)
      




    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2007/1/6 17:07:00
     
     GoogleAdSense白羊座1979-4-7
      
      
      等级:大一新生
      文章:1
      积分:50
      门派:无门无派
      院校:未填写
      注册:2007-01-01
    给Google AdSense发送一个短消息 把Google AdSense加入好友 查看Google AdSense的个人资料 搜索Google AdSense在『 软件工程论坛 』 的所有贴子 访问Google AdSense的主页 引用回复这个贴子 回复这个贴子 查看Google AdSense的博客广告
    2024/11/23 10:47:49

    本主题贴数1,分页: [1]

    管理选项修改tag | 锁定 | 解锁 | 提升 | 删除 | 移动 | 固顶 | 总固顶 | 奖励 | 惩罚 | 发布公告
    W3C Contributing Supporter! W 3 C h i n a ( since 2003 ) 旗 下 站 点
    苏ICP备05006046号《全国人大常委会关于维护互联网安全的决定》《计算机信息网络国际联网安全保护管理办法》
    3,281.250ms