http://oldboy-bj.taobao.com/

  博客园 :: 首页 :: 新随笔 :: 联系 :: 订阅 :: 管理 ::

2011年1月5日

摘要: http://35java.com/zhibo/forum.php?mod=viewthread&tid=41&extra=page%3D3给定一个语言,定义它的文法的一种表示,并定义一个解释器,这个解释器使用该表示来解释语言中的句子。适用性当有一个语言需要解释执行,并且你可将该语言中的句子表示为一个抽象语法树时,可使用解释器模式。而当存在*下情况时该模式效果最好:1.该文法简单对于复杂的文法,文法的*层次变得庞大而无法管理。2.效率不是一个关键问题最高效的解释器通常不是通过直接解释语法分析树实现的,而是首先将它们转换成另一种形式。参与者1.AbstractExpression(抽象表达式)声 阅读全文
posted @ 2011-01-05 19:52 老男孩咖啡 阅读(141) 评论(0) 推荐(0)

摘要: http://35java.com/zhibo/forum.php?mod=viewthread&tid=40&extra=page%3D3将一个请求封装为一个对象,从而使你可用不同的请求对客户进行参数化;对请求排队或记录请求日志,以及支持可撤消的*作。适用性1.抽象出待执行的动作以参数化某对象。2.在不同的时刻指定、排列和执行请求。3.支持取消操作。4.支持修改日志,这样当系统崩溃时,这*修改可以被重做一遍。5.用构建在原语操作上的高层操作构造一个系统。参与者1.Comma*d声明执行操作的接口。2.ConcreteCommand将一个接收者对象绑定于一个动作。调用接收者相应的操作,以实现E 阅读全文
posted @ 2011-01-05 19:52 老男孩咖啡 阅读(115) 评论(0) 推荐(0)

摘要: http://35java.com/zhibo/forum.php?mod=viewthread&tid=42&extra=page%3D3给定一个语言,定义它的文法的一种表示,并定义一个解释器,这个解释器使用该表示来解释语言中的句子。适用性1.访问一个聚合对象的内容而无需暴露它的内部表示。2.支持对聚合对象的多种遍历。3.为遍历不同的聚合结构提供一*统一的接口(即,支持多态迭代)。参与者1.Iterator迭代器定义访问和遍历元素的接口。2.ConcreteIterator具*迭代器实现迭代器接口。对该聚合遍历时跟踪当前位置。3.Aggregate聚合定义创建相应迭代器*象的接口。4.Con 阅读全文
posted @ 2011-01-05 19:51 老男孩咖啡 阅读(136) 评论(0) 推荐(0)

摘要: http://35java.com/zhibo/forum.php?mod=viewthread&tid=108&extra=page%3D3引言: 设计模式是经验的文档化。它是对被用来在特定场景下解决一般设计问题的类和相互通信的对象的描述。更通俗的来说,它是一个问题/解决方案对。一旦我们掌握了设计模式,就等于拥有了一支强有力的专家队伍。它甚至能够使面向对象的新手利用前人的经验找出职责明确的类和对象,从而获得优雅的解决方案。由于设计模式也是重构的目标,如果在设计的初期适当地引入设计模式,可以减少重构的工作量。 但是,我们也不能陷入模式的陷阱,为了使用模式而去套模式,那样会陷入形式主义。我们在 阅读全文
posted @ 2011-01-05 19:50 老男孩咖啡 阅读(135) 评论(0) 推荐(0)

摘要: http://35java.com/zhibo/forum.php?mod=viewthread&tid=107&extra=page%3D3基本概念 Singleton是一种创建性模型,它用来确保只产生一个实例,并提供一个访问它的全局访问点.对一些类来说,保证只有一个实例是很重要的,比如有的时候,数据库连接或Socket连接要受到一定的限制,必须保持同一时间只能有一个连接的存在.再举个例子,集合中的set中不能包含重复的元素,添加到set里的对象必须是唯一的,如果重复的值添加到set,它只接受一个实例.JDK中正式运用了Singleton模式来实现 set的这一特性,大家可以查看java.u 阅读全文
posted @ 2011-01-05 19:50 老男孩咖啡 阅读(196) 评论(0) 推荐(0)

摘要: http://35java.com/zhibo/forum.php?mod=viewthread&tid=109&extra=page%3D3引言 在分层软件体系结构中,服务端程序关注于实现业务逻辑,客户端程序则包含用户界面。服务端程序由客户端程序调用,其请求、响应模式在设计时已经确定,运行时出现问题的概率较小。相反,客户端程序与用户直接交互,虽然有正确规定的操作顺序或模式,但是用户的操作是不可预知的,程序必须处理各种操作错误、加上数据输入有效验证等要求,使得客户端程序的开发成本上升。 因而,一旦有经过充分测试的、甚至是通过验收的用户交互程序GUI,应该尽可能的重用该GUI,以提高软件的可 阅读全文
posted @ 2011-01-05 19:49 老男孩咖啡 阅读(547) 评论(0) 推荐(0)

摘要: http://35java.com/zhibo/forum.php?mod=viewthread&tid=111&extra=page%3D3在东田纳西州寒冷的一天,我的橡皮艇摇摆不定地停靠在一个十六英尺高的瀑布顶上,这个瀑布名叫州界瀑布(State Line Falls)。这条急流因为经常吞噬小船和人而臭名昭著。从顶上望过去,急流拐角处没有什么危险的迹象,但是我知道。几天以来,我在清醒的每一刻心中都记得旅行指南中对它的描述。五个卡车般大小的石块形成了四道狭缝。我只能在穿过急流的前几秒看到整个瀑布。对于这四道狭缝中的三个来说,您的岳母要穿过去可能会太费力、太危险,它们因此而闻名。急流劈波斩浪地 阅读全文
posted @ 2011-01-05 19:48 老男孩咖啡 阅读(152) 评论(0) 推荐(0)

摘要: http://35java.com/zhibo/forum.php?mod=viewthread&tid=110&extra=page%3D3控制反转(IoC)和依赖项注入(DI)是两种引起极大关注的模式(参见 参考资料)。它们主要用在所谓的 IoC 容器中,这些容器以其他组件的形式将依赖项注入到一个组件中。然而,这两种模式并未定义这些依赖项组件方法的设计方式。在经典的设计中,这些方法中的值对象或数据传输对象用作方法参数并在需要复杂对象时返回值。 本文向您展示还可以对方法签名使用 IoC,从而使方法与值对象解耦。为此,要把方法签名中的值对象替换成接口。我会介绍该方法的一些应用场景。我经常使用这 阅读全文
posted @ 2011-01-05 19:48 老男孩咖啡 阅读(169) 评论(0) 推荐(0)

摘要: http://35java.com/zhibo/forum.php?mod=viewthread&tid=140&extra=page%3D3设计模式:design patternjava中有23种设计模式. 一:设计模式是最重要的课程之一,堪称软件界的九阳真经,设计模式是一大套被反复使用,多数人知晓的,经过分类编目的,代码总结,使用设计模式是为了可重用代码.让代码更容易被他人理解,保证代码可靠性。 二:学习设计模式最常见的理由是因为我们可以借其: 1. 复用解决方案----避免重蹈前人的覆辙,从学习他人的经验中获益,用不着为那些总是会重复出现的问题再次设计解决方案. 2. 确定通用术 阅读全文
posted @ 2011-01-05 19:47 老男孩咖啡 阅读(265) 评论(0) 推荐(0)

摘要: http://35java.com/zhibo/forum.php?mod=viewthread&tid=165&extra=page%3D3下面是JDK中有关23个经典设计模式的示例,在stakeoverflow也有相应的讨论:http://stackoverflow.com/questions/1673841/examples-of-gof-design-patternsStructural(结构模式)Adapter:把一个接口或是类变成另外一种。 java.util.Arrays#asList() javax.swing.JTable(TableModel) java.io.InputS 阅读全文
posted @ 2011-01-05 19:46 老男孩咖啡 阅读(113) 评论(0) 推荐(0)

摘要: http://35java.com/zhibo/forum.php?mod=viewthread&tid=164&extra=page%3D3Java常用的设计模式创建型模式 1、FACTORY—追MM少不了请吃饭了,麦当劳的鸡翅和肯德基的鸡翅都是MM爱吃的东西,虽然口味有所不同,但不管你带MM去麦当劳或肯德基,只管向服务员说“来四个鸡翅”就行了。麦当劳和肯德基就是生产鸡翅的Factory 工厂模式:客户类和工厂类分开。消费者任何时候需要某种产品,只需向工厂请求即可。消费者无须修改就可以接纳新产品。缺点是当产品修改时,工厂类也要做相应的修改。如:如何创建及如何向客户端提供。 2、BUILDE 阅读全文
posted @ 2011-01-05 19:46 老男孩咖啡 阅读(268) 评论(0) 推荐(0)

摘要: http://35java.com/zhibo/forum.php?mod=viewthread&tid=202&extra=page%3D3我们应该从这七个方面去了解和掌握设计模式 1、 模式的介绍:名字、别名、摘要以及模式的用意 2、 模式的结构:UML图,java源代码 3、 模式的优势和劣势 4、 模式应用的场景 5、 关于模式的实现理论: 说明模式在java中实现的时候会遇到的问题,以及相应的解决方案 6、 举例 7、 相关的模式 阅读全文
posted @ 2011-01-05 19:45 老男孩咖啡 阅读(131) 评论(0) 推荐(0)

摘要: http://35java.com/zhibo/forum.php?mod=viewthread&tid=251&extra=page%3D33、 解决过多依赖实现类问题在该例的测试类Test.java中,通过Fruit apple = new Apple();来获得对象,造成了程序过多的依赖实现类,与实现类过度耦合,学习设计模式后,我们可以考虑采用工厂模式来实现,可对代码进行如下改进:增加工厂类FruitGardener.java,该类的工厂方法如下:publicstatic Fruit factory(String fruitType) ...{if (fruitType.equalsIg 阅读全文
posted @ 2011-01-05 19:44 老男孩咖啡 阅读(167) 评论(0) 推荐(0)

摘要: http://35java.com/zhibo/forum.php?mod=viewthread&tid=250&extra=page%3D3我们在发现问题到解决问题这个过程中,常会发现很多问题是重复出现的,或是某个问题的变体,外在不同,而本质相同,建筑学上如是,软件行业也是,这些问题的本质就是模式。有人说,设计模式并不是初学者能够理解的,当他们的编程经验到了一定程度,便迫切的需要设计模式来完善自己的代码、优雅自己的设计,以及减少重复编码,这句话也是蛮有道理的,以我的亲身经历来说,当刚开始编程时,拿起那本设计模式的书,郁郁寡欢,将该书搁于书架两年后再次捧起,如遇知音。本文以我在以往项目中遇到的 阅读全文
posted @ 2011-01-05 19:44 老男孩咖啡 阅读(205) 评论(0) 推荐(0)

摘要: 现在你对“什么是设计模式”已经有了感性认识,也许有人会问:“为什么要学习设计模式呢?”原因有很多,一些非常明显,而另一些则不那么明显。学习模式最常见的理由是因为我们可以借其:● 复用解决方案——通过复用已经公认的设计,我能够在解决问题时取得先发优势,而且避免重蹈前人覆辙。我可以从学习他人的经验中获益,用不着为那些总是会重复出现的问题再次设计解决方案了。● 确立通用术语——开发中的交流和协作都需要共同的词汇基础和对问题的共识。设计模式在项目的分析和设计阶段提供了共同的基准点。模式还为我们提供了观察问题、设计过程和面向对象的更高层次的视角,这将使我们从“过早处理细节”的桎梏中解放出来。等你读完本书 阅读全文
posted @ 2011-01-05 19:43 老男孩咖啡 阅读(213) 评论(0) 推荐(0)

摘要: http://35java.com/zhibo/forum.php?mod=viewthread&tid=253&extra=page%3D3设计模式是面向对象编程的热门话题之一,越来越多的开发人员认识到设计模式的重要性。采用各种语言实现设计模式的文章也越来越多,但是很多开发人员发现很难将设计模式与实际开发中需要解决的具体问题相联系。因为使用设计模式的难点往往不在于模式的实现,而在于很难确定哪种模式可以在现实的应用场景中采用,从而导致了在现实的项目中,面对客户的压力,我们总是采用最直截了当的方法解决问题,来不及多考虑这些方法的优劣,即使明知将带来更大的麻烦也必须如此。有些时候因为选择了不恰当的 阅读全文
posted @ 2011-01-05 19:43 老男孩咖啡 阅读(110) 评论(0) 推荐(0)

摘要: http://35java.com/zhibo/forum.php?mod=viewthread&tid=256&extra=page%3D3如果你的应用基于容器,那么Singleton模式少用或者不用,可以使用相关替代技术 Singleton模式看起来简单,使用方法也很方便,但是真正用好,是非常不容易,需要对Java的类 线程 内存等概念有相当的了解CoR的优点: 因为无法预知来自外界(客户端)的请求是属于哪种类型,每个类如果碰到它不能处理的请求只要放弃就可以。 缺点是效率低,因为一个请求的完成可能要遍历到最后才可能完成,当然也可以用树的概念优化。 在Java AWT1.0中,对于鼠标按 阅读全文
posted @ 2011-01-05 19:42 老男孩咖啡 阅读(142) 评论(0) 推荐(0)

摘要: http://35java.com/zhibo/forum.php?mod=viewthread&tid=255&extra=page%3D3最近一直在看《Design Patterns: Elements of Reusable Object-Oriented Software》这本书,不知道看过这本书的人是不是有摸不到头绪,无处下手的感觉, OK,和我一样/hand. 书里面讲述的23种模式经常把我弄的一蹋糊涂,这本书不看个三、四遍以上是很难理解的, 而且即便看了几遍, 也是很难把握住精髓。 里面讲解的例子是用C++和SMALLTALK这两种OO语言。对于我这种对C++半生不熟的笨鸟来说 阅读全文
posted @ 2011-01-05 19:42 老男孩咖啡 阅读(257) 评论(0) 推荐(0)

摘要: http://35java.com/zhibo/forum.php?mod=viewthread&tid=39&extra=page%3D4为子系统中的一组接口提供一个一致的界面,Facade模式定义了一个高层接口,这个接口使得这*子系统更加容易使用。适用性1.当你要为一个*杂子系统提供一个简单接口时。子系统往往因为不断演化而变得越来越复杂。大多数模式使用时都会产生更多更小的类。这使得子系统更具可重用性,也更容易对子系统进行定制,但这也给*些不需要定制子系统的用户带来一些使用上的困难。Fa*ade可以提供一个简单的缺省视图,这一视图对大多数用户来说已经足*,而那些需要更多的可定制性的用户可以越 阅读全文
posted @ 2011-01-05 19:41 老男孩咖啡 阅读(112) 评论(0) 推荐(0)

摘要: http://35java.com/zhibo/forum.php?mod=viewthread&tid=257&extra=page%3D3目前整个开发社区对AOP(Aspect Oriented Programing)推崇备至,也涌现出大量支持AOP的优秀Framework,--Spring, JAC, Jboss AOP 等等。AOP似乎一时之间成了潮流。Java初学者不禁要发出感慨,OOP还没有学通呢,又来AOP。本文不是要在理论上具体阐述何为AOP, 为何要进行AOP . 要详细了解学习AOP可以到它老家http://aosd.net去瞧瞧。这里只是意图通过一个简单的例子向初学者展示 阅读全文
posted @ 2011-01-05 19:41 老男孩咖啡 阅读(185) 评论(0) 推荐(0)

摘要: http://35java.com/zhibo/forum.php?mod=viewthread&tid=37&extra=page%3D4将对象组合成树形结构以表示"部分-整体"的层次结构。"Composite使得用户对单个对象和组合对*的使用具有一致性。"适用性1.你想表示对象的部分-整*层次结构。2.你希望用户忽略组合对象与单个对象的不同,用户将统一地使用组合结构中的所有对象。参与者1.Component为组合中的对象声明接口。在适当的情况下,实现所有类共有接口的缺省行为。声明一个接口用于访问和管理Component的子组件。(可选)在递归结构中定义一个接口,用于访问一个父部件,并在合* 阅读全文
posted @ 2011-01-05 19:40 老男孩咖啡 阅读(115) 评论(0) 推荐(0)

摘要: http://35java.com/zhibo/forum.php?mod=viewthread&tid=38&extra=page%3D4动态地给一个对象添加一些额外的职责。就增加功能来说,Decorator模*相比生成子类更为*活。适用性1.在不影响其他*象的情况下,以动态、透明的方式给单个对象添加职责。2.处理那些可以撤消的职责。3.当不能采用生成子类的方法进行扩充时。参与者1.Component定义一个对象接口,可以给这些对象动态地添加职责。2.ConcreteComponent定义一个对象,可以给这个对象添加一些职责。3.Decorator维持一个指向Component对象的指针,并 阅读全文
posted @ 2011-01-05 19:40 老男孩咖啡 阅读(112) 评论(0) 推荐(0)

摘要: http://35java.com/zhibo/forum.php?mod=viewthread&tid=36&extra=page%3D4将抽象部分与它*实现部分分离,使它们都可以独立地变化。适用性1.你不希望在抽*和它的实现部分之间有一个固定的绑定关系。例如这种情况可能是因为,在程序运行时刻实现部分应可以*选择或者切换。2.类的抽象以及它的实现都应该可以通*生成子类的方法加以扩充。这时Bridge模式使你可以对不同的抽象接口和实现部分进行组合,并分别对它们进行扩充。3.对一个抽象的实现部分的修改应对客户不产生影响,即客户的代码不必重新编译。4.正如在意图一节的第一个类图中所示的那样,有许多 阅读全文
posted @ 2011-01-05 19:39 老男孩咖啡 阅读(120) 评论(0) 推荐(0)

摘要: http://35java.com/zhibo/forum.php?mod=viewthread&tid=34&extra=page%3D4提供一个创建一系列相关或相互依赖对象的接口,而无需指定它们具体的类。适用性1.一个系统要独立于它的*品的创建、组合和表示时。2.一个系统要由多个产品系列中的一个来配置时。3.当你要强调一系列相关的产品对象的设计以便进行联合使用时*4*当你提供一个产品类库,而只想显示它们*接口而不是实现时。参与者1.Ab*tractFactory声明一个创建抽象产品对象的操作接口。2.ConcreteFactory实现创建具体产品对象的操作。*.AbstractProduc 阅读全文
posted @ 2011-01-05 19:38 老男孩咖啡 阅读(128) 评论(0) 推荐(0)

摘要: http://35java.com/zhibo/forum.php?mod=viewthread&tid=35&extra=%26page%3D4将一个类的接口转换成客户希望的另外一个接口。Adapter模式使得原本由于接口*兼容而不能一起工作的那*类可以一起工作。适用性1.你想使*一个已经存在的类,而它的接口不符合你的需求。2.你想创建一个可以复用的类,该类可以与其他不相关的类或不可预见的类(即那*接口可能不一定兼容的类)协同工作。*.(仅适用于对象Adapter)你想使用一些已经存在的子类,但是不可能对每一个都进行子类化以匹配它们的接口。对象适配器可以适配它的父类接口。参与者1.Targe 阅读全文
posted @ 2011-01-05 19:38 老男孩咖啡 阅读(128) 评论(0) 推荐(0)

摘要: 定义一个用于创建对象的接口,让子类决定实例化哪一个类。FactoryMethod使一个类的实例。适用性1.当一个类不知道它所必须创建的对象的类的时候。2.当一个类希望由它的子类来指定它所创建的对象的时候。3.当*将创建对象的职责委托给多个帮助*类中的某一个,并且*希望将哪一个帮助子类是代理者这一信息局部化的时候。参与者1.Product定义工厂方法所创建的对象的接口。2.ConcreteProduct实现Product接口。3.Creator声明工厂方法,该方法返回一个Product类型的对象*Creator也可以定义一个工厂方法的缺省实现,它返回一个缺省的ConcreteProduct对象。 阅读全文
posted @ 2011-01-05 19:37 老男孩咖啡 阅读(264) 评论(0) 推荐(0)

摘要: http://35java.com/zhibo/forum.php?mod=viewthread&tid=386&extra=page%3D1adb shell sdutil mount /sdcard 插卡adb shell sdutil unmount /sdcard 拔卡 阅读全文
posted @ 2011-01-05 19:36 老男孩咖啡 阅读(721) 评论(0) 推荐(0)

摘要: http://35java.com/zhibo/forum.php?mod=viewthread&tid=388&extra=page%3D1在Android开发中对资源的引用是很重要的内容,看一个Android工程结构的好与坏,其实看看工程结构的资源文件的相互关系就大概可以看出来了,个人觉得学习好Android,资源文件是很重要的部分,这里讲的都是些入门级别的知识点,耐下心思看哦,呵呵。1,三种资源文件形式。资源文件之间的相互引用自然是基础的基础,三种形式(android:xxx/yyy,@xxxx/yyy,?xxx)的区别要彻底地弄明白。2,资源文件的属性命名。资源文件属性的命名(其实大部 阅读全文
posted @ 2011-01-05 19:35 老男孩咖啡 阅读(441) 评论(0) 推荐(1)

摘要: http://35java.com/zhibo/forum.php?mod=viewthread&tid=387&extra=page%3D1学习Android差不多已经两周多了,自己认为Android的框架还是蛮不错了,只是提供的类库的的继承关系和方法的命名实在不是很爽,这方面负责Android Google的工程师可能还要向Sun学习,一个类好几十个方法甚至上百个,有的时候头都找晕了。好了,一个初学者的态度来将好了,怎么才能快速入门呢?如果有一年以上的工作经验学习Android,如果有过J2EE工作经验的更好,因为J2EE整天有很多xml的配置文件,至少看见了这么多的xml配置文件不会晕头 阅读全文
posted @ 2011-01-05 19:35 老男孩咖啡 阅读(300) 评论(0) 推荐(0)