- 浏览: 593853 次
- 性别:
- 来自: 厦门
文章分类
- 全部博客 (669)
- oracle (36)
- java (98)
- spring (48)
- UML (2)
- hibernate (10)
- tomcat (7)
- 高性能 (11)
- mysql (25)
- sql (19)
- web (42)
- 数据库设计 (4)
- Nio (6)
- Netty (8)
- Excel (3)
- File (4)
- AOP (1)
- Jetty (1)
- Log4J (4)
- 链表 (1)
- Spring Junit4 (3)
- Autowired Resource (0)
- Jackson (1)
- Javascript (58)
- Spring Cache (2)
- Spring - CXF (2)
- Spring Inject (2)
- 汉字拼音 (3)
- 代理模式 (3)
- Spring事务 (4)
- ActiveMQ (6)
- XML (3)
- Cglib (2)
- Activiti (15)
- 附件问题 (1)
- javaMail (1)
- Thread (19)
- 算法 (6)
- 正则表达式 (3)
- 国际化 (2)
- Json (3)
- EJB (3)
- Struts2 (1)
- Maven (7)
- Mybatis (7)
- Redis (8)
- DWR (1)
- Lucene (2)
- Linux (73)
- 杂谈 (2)
- CSS (13)
- Linux服务篇 (3)
- Kettle (9)
- android (81)
- protocol (2)
- EasyUI (6)
- nginx (2)
- zookeeper (6)
- Hadoop (41)
- cache (7)
- shiro (3)
- HBase (12)
- Hive (8)
- Spark (15)
- Scala (16)
- YARN (3)
- Kafka (5)
- Sqoop (2)
- Pig (3)
- Vue (6)
- sprint boot (19)
- dubbo (2)
- mongodb (2)
最新评论
单例模式
实现要点
* 声明为private来隐藏构造器
* private static Singleton实例
* 声明为public来暴露实例获取方法
单例模式主要追求三个方面性能
* 线程安全
* 调用效率高
* 延迟加载
工厂模式
工厂模式主要是为创建对象提供过渡接口,以便将创建对象的具体过程屏蔽隔离起来,达到提高灵活性的目的。
1.命令模式
转自:http://blog.csdn.net/jason0539/article/details/45110355
2.组合模式
转自:http://blog.csdn.net/jason0539/article/details/22642281
3.装饰模式
转自:http://blog.csdn.net/jason0539/article/details/22713711
4.原型模式
转自:http://blog.csdn.net/jason0539/article/details/23158081
5.代理模式
转自:http://blog.csdn.net/jason0539/article/details/22974405
6.策略模式
转自:http://blog.csdn.net/jason0539/article/details/45007553
实现要点
* 声明为private来隐藏构造器
* private static Singleton实例
* 声明为public来暴露实例获取方法
单例模式主要追求三个方面性能
* 线程安全
* 调用效率高
* 延迟加载
public class Singleton { private static volatile Singleton instance; private Singleton() { }; public static Singleton getInstance() { if (instance == null) { synchronized (Singleton.class) { if (instance == null) { instance = new Singleton(); } } } return instance; } }
工厂模式
工厂模式主要是为创建对象提供过渡接口,以便将创建对象的具体过程屏蔽隔离起来,达到提高灵活性的目的。
//抽象产品角色 public interface Moveable { void run(); } //具体产品角色 public class Plane implements Moveable { @Override public void run() { System.out.println("plane...."); } } public class Broom implements Moveable { @Override public void run() { System.out.println("broom....."); } } //抽象工厂 public abstract class VehicleFactory { abstract Moveable create(); } //具体工厂 public class PlaneFactory extends VehicleFactory{ public Moveable create() { return new Plane(); } } public class BroomFactory extends VehicleFactory{ public Moveable create() { return new Broom(); } } //测试类 public class Test { public static void main(String[] args) { VehicleFactory factory = new BroomFactory(); Moveable m = factory.create(); m.run(); } }
1.命令模式
package com.controller; /** * @author: * @TODO:命令模式 */ public class CommandTest { public static void main(String[] args) { Tv myTv = new Tv(); CommandOn on = new CommandOn(myTv); CommandOff off = new CommandOff(myTv); CommandChange channel = new CommandChange(myTv, 2); Control control = new Control(on, off, channel); control.turnOn(); control.changeChannel(); control.turnOff(); } } /** * @author: * @TODO:命令借口 */ interface Command { void execute(); } class Tv { public int currentChannel = 0; public void turnOn() { System.out.println("The televisino is on."); } public void turnOff() { System.out.println("The television is off."); } public void changeChannel(int channel) { this.currentChannel = channel; System.out.println("Now TV channel is " + channel); } } // 开机命令ConcreteCommand class CommandOn implements Command { private Tv myTv; public CommandOn(Tv tv) { myTv = tv; } public void execute() { myTv.turnOn(); } } // 关机命令ConcreteCommand class CommandOff implements Command { private Tv myTv; public CommandOff(Tv tv) { myTv = tv; } public void execute() { myTv.turnOff(); } } // 频道切换命令ConcreteCommand class CommandChange implements Command { private Tv myTv; private int channel; public CommandChange(Tv tv, int channel) { myTv = tv; this.channel = channel; } public void execute() { myTv.changeChannel(channel); } } // 可以看作是遥控器Invoker class Control { private Command onCommand, offCommand, changeChannel; public Control(Command on, Command off, Command channel) { onCommand = on; offCommand = off; changeChannel = channel; } public void turnOn() { onCommand.execute(); } public void turnOff() { offCommand.execute(); } public void changeChannel() { changeChannel.execute(); } }
转自:http://blog.csdn.net/jason0539/article/details/45110355
2.组合模式
package com.controller; import java.util.ArrayList; import java.util.List; public class ComponentTest { public abstract class Component { String name; public abstract void add(Component c); public abstract void remove(Component c); public abstract void eachChild(); } // 组合部件类 public class Leaf extends Component { // 叶子节点不具备添加的能力,所以不实现 @Override public void add(Component c) { System.out.println(""); } // 叶子节点不具备添加的能力必然也不能删除 @Override public void remove(Component c) { System.out.println(""); } // 叶子节点没有子节点所以显示自己的执行结果 @Override public void eachChild() { System.out.println(name + "执行了"); } } // 组合类 public class Composite extends Component { // 用来保存节点的子节点 List<Component> list = new ArrayList<Component>(); // 添加节点 添加部件 @Override public void add(Component c) { list.add(c); } // 删除节点 删除部件 @Override public void remove(Component c) { list.remove(c); } // 遍历子节点 @Override public void eachChild() { System.out.println(name + "执行了"); for (Component c : list) { c.eachChild(); } } } public static void main(String[] args) { ComponentTest demo = new ComponentTest(); // 构造根节点 Composite rootComposite = demo.new Composite(); rootComposite.name = "根节点"; // 左节点 Composite compositeLeft = demo.new Composite(); compositeLeft.name = "左节点"; // 构建右节点,添加两个叶子几点,也就是子部件 Composite compositeRight = demo.new Composite(); compositeRight.name = "右节点"; Leaf leaf1 = demo.new Leaf(); leaf1.name = "右-子节点1"; Leaf leaf2 = demo.new Leaf(); leaf2.name = "右-子节点2"; compositeRight.add(leaf1); compositeRight.add(leaf2); // 左右节点加入 根节点 rootComposite.add(compositeRight); rootComposite.add(compositeLeft); // 遍历组合部件 rootComposite.eachChild(); } }
转自:http://blog.csdn.net/jason0539/article/details/22642281
3.装饰模式
package com.controller; //定义公共接口 interface Human { public void wearClothes(); public void walkToWhere(); } // 定义装饰者 abstract class Decorator implements Human { private Human human; public Decorator(Human human) { this.human = human; } public void wearClothes() { human.wearClothes(); } public void walkToWhere() { human.walkToWhere(); } } // 下面定义三种装饰,这是第一个,第二个第三个功能依次细化,即装饰者的功能越来越多 class Decorator_zero extends Decorator { public Decorator_zero(Human human) { super(human); } public void goHome() { System.out.println("进房子。。"); } public void findMap() { System.out.println("书房找找Map。。"); } @Override public void wearClothes() { super.wearClothes(); goHome(); } @Override public void walkToWhere() { super.walkToWhere(); findMap(); } } // 定义被装饰者,被装饰者初始状态有些自己的装饰 class Person implements Human { @Override public void wearClothes() { System.out.println("穿什么呢。。"); } @Override public void walkToWhere() { System.out.println("去哪里呢。。"); } } // 测试类,看一下你就会发现,跟java的I/O操作有多么相似 public class DecoratorTest { public static void main(String[] args) { Human person = new Person(); Decorator decorator = new Decorator_zero(person); decorator.wearClothes(); decorator.walkToWhere(); } }
转自:http://blog.csdn.net/jason0539/article/details/22713711
4.原型模式
package com.controller; import net.sf.cglib.beans.BeanCopier; /** * @author: * @TODO:原型模式 */ public class PrototypeTest extends Prototype{ public static void main(String[] args) { BO bo = new BO(); bo.setAge(27); CloneClass cp = new CloneClass("lau",bo); CloneClass clonecp = null ; CloneClass beanCopy = new CloneClass() ; try { clonecp = (CloneClass)cp.clone(); } catch (CloneNotSupportedException e) { e.printStackTrace(); } clonecp.doIt(); BeanCopier bc = BeanCopier.create(CloneClass.class, CloneClass.class, false); bc.copy(cp, beanCopy, null); beanCopy.doIt(); } } /** * @author: * @TODO:克隆类 */ class Prototype implements Cloneable{ @Override public Object clone() throws CloneNotSupportedException { Prototype prototype = null; try{ prototype = (Prototype)super.clone(); }catch(CloneNotSupportedException e){ e.printStackTrace(); } return prototype; } } class CloneClass extends Prototype { private String name ; private BO bo ; public CloneClass(){ } public CloneClass(String name,BO bo){ this.name = name ; this.bo = bo ; } public BO getBo() { return bo; } public void setBo(BO bo) { this.bo = bo; } public String getName() { return name; } public void setName(String name) { this.name = name; } public void doIt(){ System.out.println(name+" I am "+bo.getAge()); } } class BO{ private int age ; public int getAge() { return age; } public void setAge(int age) { this.age = age; } }
转自:http://blog.csdn.net/jason0539/article/details/23158081
5.代理模式
package com.controller; /** * @author: * @TODO:代理模式 */ public class ProxyTest { public static void main(String[] args) { People people_1 = new People(); people_1.setCash(60000); people_1.setUsername("jeck"); People people_2 = new People(); people_2.setCash(40000); people_2.setUsername("rose"); People people_3 = new People(); people_3.setCash(0); people_3.setUsername("tom"); people_3.setVip("vip"); ProxyClass proxy_buy = new ProxyClass(); proxy_buy.setPeople(people_1); proxy_buy.buy_mycar(); proxy_buy.setPeople(people_2); proxy_buy.buy_mycar(); proxy_buy.setPeople(people_3); proxy_buy.buy_mycar(); } } interface CarShop { public void buy_mycar(); } class People implements CarShop { private int cash; private String vip; private String username; @Override public void buy_mycar() { System.out.print(username + "是vip 客户,可以直接购买新车!"); } public int getCash() { return cash; } public void setCash(int cash) { this.cash = cash; } public String getUsername() { return username; } public void setUsername(String username) { this.username = username; } public String getVip() { return vip; } public void setVip(String vip) { this.vip = vip; } } class ProxyClass implements CarShop { private People people; public People getPeople() { return people; } public void setPeople(People people) { this.people = people; } @Override public void buy_mycar() { if (people.getVip() == "vip") { people.buy_mycar(); return; } if (people.getCash() >= 50000) { System.out.println(people.getUsername() + " 买了新车,交易结束!"); } else { System.out.println(people.getUsername() + " 钱不够,不能买车,继续比赛!"); } } }
转自:http://blog.csdn.net/jason0539/article/details/22974405
6.策略模式
package com.controller; /** * @author: * @TODO:策略模式 */ public class StrategyTest { public static void main(String[] args) { Context context; System.out.println("----------刚到吴国使用第一个锦囊---------------"); context = new Context(new BackDoor()); context.operate(); System.out.println("\n"); System.out.println("----------刘备乐不思蜀使用第二个锦囊---------------"); context.setStrategy(new GivenGreenLight()); context.operate(); System.out.println("\n"); System.out.println("----------孙权的追兵来了,使用第三个锦囊---------------"); context.setStrategy(new BlackEnemy()); context.operate(); System.out.println("\n"); } } /** * @author: * @TODO:策略接口 */ interface IStrategy { public void operate(); } class BackDoor implements IStrategy { @Override public void operate() { System.out.println("找乔国老帮忙,让吴国太给孙权施加压力,使孙权不能杀刘备"); } } class GivenGreenLight implements IStrategy { @Override public void operate() { System.out.println("求吴国太开个绿灯,放行"); } } class BlackEnemy implements IStrategy { @Override public void operate() { System.out.println("孙夫人断后,挡住追兵"); } } class Context { private IStrategy strategy; // 构造函数,要你使用哪个妙计 public Context(IStrategy strategy) { this.strategy = strategy; } public void setStrategy(IStrategy strategy) { this.strategy = strategy; } public void operate() { this.strategy.operate(); } }
转自:http://blog.csdn.net/jason0539/article/details/45007553
发表评论
文章已被作者锁定,不允许评论。
-
java WeakHashMap学习(key是弱引用)
2018-06-21 09:31 1225在Java集合中有一种特殊的Map类型:WeakHashMap ... -
java HashMap TreeMap(key顺序) LinkedHashMap(插入顺序)学习
2018-06-07 10:27 942java为数据结构中的映射定义了一个接口java.util.M ... -
java RESTful 详解
2018-04-27 11:35 636(1)每一个URI代表一种资源,独一无二; (2)客户端 ... -
java 通过HttpsUrlConnection访问接口数据
2018-04-19 11:25 979server: ssl: key-stor ... -
java 使用多线程的场景总结
2018-04-10 14:35 1694在一个高并发的网站中,多线程是必不可少的。下面先说一下多线程在 ... -
java Enum枚举设置
2018-04-10 10:55 475/** * 数据状态:0:无效,1:有效 **/ ... -
java RestTemplate访问restful服务
2018-03-01 15:02 1606REST的基础知识 当谈论REST时,有一种常见的错误就是将其 ... -
java FYOpenApi实现短信发送
2018-01-02 17:10 11521.配置文件 sms.OpenUrl = http://s ... -
java JSONObject序列化包含Date类型数据的Java对象
2017-12-26 16:31 1607如果Date.class无法进行转换则使用Timestamp. ... -
java 用HttpsURLConnection进行传递中文时错误总结
2017-12-07 16:42 646传递中文时需要用Writer而不是OutputStream ... -
java 内存泄漏
2017-11-27 13:51 4901.内存溢出 out of memory ... -
ActiveMQ 三种发送消息方式(同步,异步,单向)
2017-11-17 10:25 2425MQ 发送普通消息有三种实现方式:可靠同步发送、可靠异步发送、 ... -
java Guava ListenableFuture实现线程回调功能
2017-11-14 10:17 1772java Future具有局限性。在实际应用中,当需要下 ... -
java Curator实现分布式锁
2017-09-05 14:39 1085Curator实现分布式锁主要依赖于zookeeper ... -
java Guava工具集学习(强大)
2017-09-05 10:28 429import java.util.Iterator ... -
java CyclicBarrier进行并发编程
2017-08-25 15:44 665CyclicBarrier允许一组线程相互等待达到一个公共的障 ... -
java 几种性能优化的总结
2017-08-23 14:08 3111、使用StringBuilder 一般 ... -
java 使用kyro进行高性能序列化对象和集合
2017-08-23 14:05 2139import java.io.ByteArrayInp ... -
java 对重复电话号码进行排除的优化(排序和前后对比)
2017-08-22 14:14 7801.先对10万数据排序; 2.对比前后两条数据 ; 3.筛 ... -
ActiveMQ 结合Spring进行数据同步
2017-07-19 15:27 579注意事项hibernate配置文件必须设置自动提交否则不能插入 ...
相关推荐
Java 经典设计模式讲解以及项目实战 设计模式简介:主要介绍各种设计模式的概念和运用场景等 设计模式综合运用:主要是笔者在实际工作中运用到的一些设计模式综合运用事例的提炼 Spring设计模式简介:主要是讲述...
本资料“java设计模式学习”包含了对设计模式的深入理解和实际应用,通过简单实用的例子,帮助开发者掌握如何在Java项目中运用设计模式。 首先,我们要介绍的是工厂模式。工厂模式是一种创建型设计模式,它提供了一...
Java设计模式是面向对象编程领域中的重要概念,它是一套被广泛接受并实践的解决软件设计问题的经验总结。设计模式并非具体的代码或库,而是一种在特定情境下为了解决常见问题而制定的通用解决方案的描述。它们描述了...
### Java设计模式详解 ...通过以上内容可以看出,《Java设计模式PDF》这本书不仅提供了对各种设计模式的详细介绍,而且还结合了大量的示例代码和实用建议,对于Java开发者来说是一本非常有价值的参考书。
《Java设计模式》课程设计报告主要探讨了如何利用Java编程语言和MyEclipse集成开发环境来实现基于设计模式的西瓜市场系统。这个项目涵盖了四种重要的设计模式:单例模式、代理模式、建造者模式和抽象工厂模式,为...
文档中描述的是Java设计模式学习笔记,目前涉及了7种设计模式,但没有具体指明这7种模式是什么,计划后续增加更多的模式。虽然文件内容中存在OCR扫描的识别错误,但不影响我们从整体上把握设计模式的脉络和学习方法...
Java设计模式是软件工程中的一种最佳实践,它提供了一种在特定情况下解决常见问题的模板。这些模式来自于经验丰富的...这个压缩包中的各种版本的资源,无论是中文还是英文,都能为你的设计模式学习提供宝贵的资料。
这份"图解java设计模式_学习笔记"是针对Java开发者深入理解和应用设计模式的重要资源。在这里,我们将深入探讨Java设计模式的核心概念、分类以及它们在实际开发中的应用。 设计模式分为三大类:创建型、结构型和...
学习Java设计模式不仅可以提升个人编程技能,也是团队开发中沟通交流的重要基础。设计模式的应用可以降低代码复杂度,提高代码复用性,使得软件系统更加健壮和易于维护。例如,单例模式用于保证一个类只有一个实例,...
在这本"Java 企业设计模式"的书中,读者可以学习到如何有效地应用这些模式,以提升自己的编程技巧和系统设计能力。 设计模式通常分为三类:创建型模式、结构型模式和行为型模式。创建型模式如单例(Singleton)、...
Java设计模式是软件开发中的重要概念,它是一种在特定情境下解决常见问题...在阅读《JAVA设计模式java 各种设计模式》的.chm文件时,你可以深入学习每个模式的原理、实现方式以及使用场景,进一步提升自己的编程技能。
本资料“《java设计模式》课后习题模拟试题解答——刘伟.zip”主要涵盖了Java设计模式的学习与应用,特别是针对刘伟教授的相关课程的课后习题及模拟试题的解答。 设计模式分为三大类:创建型、结构型和行为型模式。...
### Java设计模式(刘伟) #### 一、引言 在《Java设计模式》这本书中,作者刘伟全面地介绍了24种经典的设计模式,并通过丰富的案例和代码示例进行了详细的解析。本书不仅适合初学者作为入门教材,也适合有一定...
《Java设计模式》是刘伟教授的一本关于设计模式的教材,主要面向高等学校的学生和对Java编程有深入兴趣的开发者。设计模式是软件工程中的一种重要思想,它封装了在特定场景下的问题解决方案,可以提高代码的可读性、...
《Head First 设计模式》与《Java设计模式(第2版)》是两本非常重要的IT书籍,专注于软件开发中的设计模式。设计模式是解决软件设计中常见问题的经验总结,它们提供了一种标准的方法来处理特定场景下的问题,使得代码...
基于Java的设计模式学习网站的设计与实现论文 本论文旨在设计和实现一个基于Java的设计模式学习网站,满足现代计算机系统从计算中心向信息化处理中心的发展需求。该网站系统使用Struts2框架,基于Eclipse集成开发...
通过学习这本“Java版设计模式教程”,开发者不仅可以掌握各种设计模式的实现,还能学会如何根据实际需求选择合适的设计模式,提升代码质量和可维护性。此外,设计模式也是面试中常见的考察点,熟练掌握设计模式对于...
通过学习和应用这些设计模式,Java开发者可以写出更加优雅、灵活的代码,提升系统的可维护性和可扩展性。在实际项目中,合理选择和组合设计模式可以有效地解决复杂问题,提高代码质量,降低维护成本。因此,深入理解...
设计模式(Design pattern)是一套被反复使用、...本章系Java之美[从菜鸟到高手演变]系列之设计模式,我们会以理论与实践相结合的方式来进行本章的学习,希望广大程序爱好者,学好设计模式,做一个优秀的软件工程师!