java几种常用设计模式简单示例
1.单例设计模式
所谓单例设计模式简单说就是无论程序如何运行,采用单例设计模式的类(Singleton类)永远只会有一个实例化对象产生。具体实现步骤如下:
(1) 将采用单例设计模式的类的构造方法私有化(采用private修饰)。
(2) 在其内部产生该类的实例化对象,并将其封装成private static类型。
(3) 定义一个静态方法返回该类的实例。
示例代码如下:
- class Singleton {
- private static Singleton instance = new Singleton();// 在内部产生本类的实例化对象
- public static Singleton getInstance() { // 通过静态方法返回instance对象
- return instance;
- }
- private Singleton() { // 将构造方法封装为私有化
- }
- public void print() {
- System.out.println("Hello World!!!");
- }
- }
- public class SingletonDemo {
- public static void main(String args[]) {
- Singleton s1 = null; // 声明对象
- Singleton s2 = null; // 声明对象
- Singleton s3 = null; // 声明对象
- s1 = Singleton.getInstance(); // 取得实例化对象
- s2 = Singleton.getInstance(); // 取得实例化对象
- s3 = Singleton.getInstance(); // 取得实例化对象
- s1.print(); // 调用方法
- s2.print(); // 调用方法
- s3.print(); // 调用方法
- }
- }
单例模式的实现
- /**
- *
- * 单例模式的实现:饿汉式,线程安全 但效率比较低
- */
- public class SingletonTest {
- private SingletonTest() {
- }
- private static final SingletonTest instance = new SingletonTest();
- public static SingletonTest getInstancei() {
- return instance;
- }
- }
- /**
- * 单例模式的实现:懒汉式,非线程安全
- *
- */
- public class SingletonTest {
- private SingletonTest() {
- }
- private static SingletonTest instance;
- public static SingletonTest getInstance() {
- if (instance == null)
- instance = new SingletonTest();
- return instance;
- }
- }
- /**
- * 线程安全,但是效率非常低
- * @author vanceinfo
- *
- */
- public class SingletonTest {
- private SingletonTest() {
- }
- private static SingletonTest instance;
- public static synchronized SingletonTest getInstance() {
- if (instance == null)
- instance = new SingletonTest();
- return instance;
- }
- }
- /**
- * 线程安全 并且效率高
- *
- */
- public class SingletonTest {
- private static SingletonTest instance;
- private SingletonTest() {
- }
- public static SingletonTest getIstance() {
- if (instance == null) {
- synchronized (SingletonTest.class) {
- if (instance == null) {
- instance = new SingletonTest();
- }
- }
- }
- return instance;
- }
- }
2.工厂设计模式
程序在接口和子类之间加入了一个过渡端,通过此过渡端可以动态取得实现了共同接口的子类实例化对象。
示例代码如下:
- interface Animal { // 定义一个动物的接口
- public void say(); // 说话方法
- }
- class Cat implements Animal { // 定义子类Cat
- @Override
- public void say() { // 覆写say()方法
- System.out.println("我是猫咪,喵呜!");
- }
- }
- class Dog implements Animal { // 定义子类Dog
- @Override
- public void say() { // 覆写say()方法
- System.out.println("我是小狗,汪汪!");
- }
- }
- class Factory { // 定义工厂类
- public static Animal getInstance(String className) {
- Animal a = null; // 定义接口对象
- if ("Cat".equals(className)) { // 判断是哪个子类的标记
- a = new Cat(); // 通过Cat子类实例化接口
- }
- if ("Dog".equals(className)) { // 判断是哪个子类的标记
- a = new Dog(); // 通过Dog子类实例化接口
- }
- return a;
- }
- }
- public class FactoryDemo {
- public static void main(String[] args) {
- Animal a = null; // 定义接口对象
- a = Factory.getInstance(args[0]); // 通过工厂获取实例
- if (a != null) { // 判断对象是否为空
- a.say(); // 调用方法
- }
- }
- }
3.代理设计模式
指由一个代理主题来操作真实主题,真实主题执行具体的业务操作,而代理主题负责其他相关业务的处理。比如生活中的通过代理访问网络,客户通过网络代理连接网络(具体业务),由代理服务器完成用户权限和访问限制等与上网相关的其他操作(相关业务)。
示例代码如下:
- interface Network { // 定义Network接口
- public void browse(); // 定义浏览的抽象方法
- }
- class Real implements Network { // 真实的上网操作
- public void browse() { // 覆写抽象方法
- System.out.println("上网浏览信息!");
- }
- }
- class Proxy implements Network { // 代理上网
- private Network network;
- public Proxy(Network network) {// 设置代理的真实操作
- this.network = network; // 设置代理的子类
- }
- public void check() { // 身份验证操作
- System.out.println("检查用户是否合法!");
- }
- public void browse() {
- this.check(); // 调用具体的代理业务操作
- this.network.browse(); // 调用真实的上网操作
- }
- }
- public class ProxyDemo {
- public static void main(String args[]) {
- Network net = null; // 定义接口对象
- net = new Proxy(new Real()); // 实例化代理,同时传入代理的真实操作
- net.browse(); // 调用代理的上网操作
- }
- }
4.观察者设计模式
所谓观察者模式,举个例子现在许多购房者都密切观察者房价的变化,当房价变化时,所有购房者都能观察到,以上的购房者属于观察者,这便是观察者模式。
java中可以借助Observable类和Observer接口轻松实现以上功能。当然此种模式的实现也不仅仅局限于采用这两个类。
示例代码如下:
- import java.util.Observable;
- import java.util.Observer;
- class House extends Observable {
- private float price;
- public void setPrice(float price) {
- this.setChanged();// 设置变化点
- this.notifyObservers(price);// 通知所有观察者价格改变
- this.price = price;
- }
- public float getPrice() {
- return this.price;
- }
- public House(float price) {
- this.price = price;
- }
- public String toString() {
- return "房子价格为: " + this.price;
- }
- }
- class HousePriceObserver implements Observer {
- private String name;
- public HousePriceObserver(String name) {
- super();
- this.name = name;
- }
- @Override
- public void update(Observable o, Object arg) {// 只要改变了 observable 对象就调用此方法
- if (arg instanceof Float) {
- System.out.println(this.name + "观察的价格更改为:"
- + ((Float) arg).floatValue());
- }
- }
- }
- public class ObserDeom {
- public static void main(String[] args) {
- House h = new House(1000000);
- HousePriceObserver hpo1 = new HousePriceObserver("购房者A");
- HousePriceObserver hpo2 = new HousePriceObserver("购房者B");
- HousePriceObserver hpo3 = new HousePriceObserver("购房者C");
- h.addObserver(hpo1);// 给房子注册观察者
- h.addObserver(hpo2);// 给房子注册观察者
- h.addObserver(hpo3);// 给房子注册观察者
- System.out.println(h);// 输出房子价格
- // 修改房子价格,会触发update(Observable o, Object arg)方法通知购房者新的房价信息
- h.setPrice(2222222);//
- System.out.println(h);// 再次输出房子价格
- }
- }
5.适配器模式
如果一个类要实现一个具有很多抽象方法的接口,但是本身只需要实现接口中的部分方法便可以达成目的,所以此时就需要一个中间的过渡类,但此过渡类又不希望直接使用,所以将此类定义为抽象类最为合适,再让以后的子类直接继承该抽象类便可选择性的覆写所需要的方法,而此抽象类便是适配器类。
示例代码如下:
- interface Window {// 定义Window窗口接口,表示窗口操作
- public void open();// 窗口打开
- public void close();// 窗口关闭
- public void iconified();// 窗口最小化
- public void deiconified();// 窗口恢复
- public void activated();// 窗口活动
- }
- // 定义抽象类实现接口,在此类中覆写方法,但是所有的方法体为空
- abstract class WindowAdapter implements Window {
- public void open() {
- };// 窗口打开
- public void close() {
- };// 窗口关闭
- public void iconified() {
- };// 窗口最小化
- public void deiconified() {
- };// 窗口恢复
- public void activated() {
- };// 窗口活动
- }
- // 子类继承WindowAdapter抽象类,选择性实现需要的方法
- class WindowImpl extends WindowAdapter {
- public void open() {
- System.out.println("窗口打开");// 实现open()方法
- }
- public void close() {
- System.out.println("窗口关闭");// 实现close()方法
- }
- }
- public class AdapterDemo {
- public static void main(String args[]) {
- Window win = new WindowImpl(); // 实现接口对象
- // 调用方法
- win.open();
- win.close();
- }
- }
装饰者模式
/*
装饰设计模式:
当想要对已有的对象进行功能增强时,
可以定义类,将已有对象传入,基于已有的功能,并提供加强功能
那么自定义的该类称为装饰类 例子:
BufferedReader和FileReader BufferedReader(FileReader)
readline 和 read,这两个方法 装饰类通常会通过构造方法接收被装饰的对象
并基于被装饰的对象的功能,提供更强的功能 */ import java.io.*; public class PersonDemo
{
public static void main(String args[])
{
Person p = new Person();
SuperPerson sp = new SuperPerson(p);
sp.superChifan();
} public static void sop(Object obj)
{
System.out.println(obj);
}
} class Person
{
public void chifan()
{
System.out.println("吃饭");
} } class SuperPerson
{
private Person p ;
SuperPerson(Person p)
{
this.p = p;
}
public void superChifan()
{
System.out.println("开胃菜");
p.chifan();
System.out.println("甜点");
}
}
装饰设计模式
package pack; import java.io.*; public class Demo {
public static void main(String args[]) throws IOException {
FileReader fr = new FileReader("ltp.txt");
MyBufferedReader myBuf = new MyBufferedReader(fr);
String line = null;
while ((line = myBuf.myReadLine()) != null) {
System.out.println(line);
}
myBuf.myClose();
} public static void sop(Object obj) {
System.out.println(obj);
}
} class MyBufferedReader {
private FileReader r; MyBufferedReader(FileReader r) {
this.r = r;
} // 可以一次读一行数组
public String myReadLine() throws IOException {
// 用StringBuilder容器
StringBuilder sb = new StringBuilder();
int ch = ;
while ((ch = r.read()) != -) {
if (ch == '\r')
continue;
if (ch == '\n')// 这里的东西都是临时的,不用在这里把sb 设置成空.
return sb.toString();
else
sb.append((char) ch);
} //当到最后一行的时候,r.read()返回-1,StringBuilder没有toString.要在外面toString
if (sb.length() != )
return sb.toString(); return null;
} public void myClose() throws IOException {
r.close();
} }
http://blog.csdn.net/haoxingfeng/article/details/9191619
java几种常用设计模式简单示例的更多相关文章
- C++源码实现:21种常用设计模式
C++源码实现:21种常用设计模式一直以来在设计模式的学习中,都是出现java的源码,这对学习C++的极度不友好.本工程是基于C++实现21种常用的设计模式,里面包含了实例代码和示例.编写的时候在学习 ...
- java读取ACCESS数据库的简单示例
java读取ACCESS数据库的简单示例 虽然简单,对初学者来说,如果没有一段可以成功执行的代码供参考,还真难调试 先用ACCESS建一个数据库 DB1.MDB,里面有一表"table1&q ...
- JAVA使用jdbc连接MYSQL简单示例
以下展示的为JAVA使用jdbc连接MYSQL简单示例: import java.sql.DriverManager; import java.sql.ResultSet; import java.s ...
- javaEE Design Patter(1)初步了解23种常用设计模式
设计模式分为三大类: 创建型模式,共五种:工厂方法模式.抽象工厂模式.单例模式.建造者模式.原型模式. 结构型模式,共七种:适配器模式.装饰器模式.代理模式.外观模式.桥接模式.组合模式.享元模式. ...
- 23种常用设计模式的UML类图
23种常用设计模式的UML类图 本文UML类图参考<Head First 设计模式>(源码)与<设计模式:可复用面向对象软件的基础>(源码)两书中介绍的设计模式与UML图. 整 ...
- 转载:23种常用设计模式的UML类图
转载至:https://www.cnblogs.com/zytrue/p/8484806.html 23种常用设计模式的UML类图 本文UML类图参考<Head First 设计模式>(源 ...
- Java的几种常用设计模式
何为设计模式? 就是对一些常见问题进行归纳总结,并针对具体问题给出一套通用的解决办法(强调的是解决问题的思想): 在开发中,只要遇到这类问题,就可以直接使用这些设计模式解决问题. ---------- ...
- java学习之三种常用设计模式
一.适配器设计模式 简单来说,就是通过一个间接类来选择性的来覆写一个接口 interface Window{ public void open() ; // 打开窗口 public void clos ...
- Java UDP网络编程 - 最简单示例
UDP也是网络通讯中的一个重要协议,与TCP区别可参见浅谈TCP/IP 和 UDP的区别,本文就对Java UDP通讯做一个简单例子介绍 服务端: package wyf; import java.i ...
随机推荐
- json处理三部曲之第三曲:利用Gson处理json
需要导入gson-xxx.jar包 <dependency> <groupId>com.google.code.gson</groupId> <artifac ...
- Pyramid of Glasses(递推)
Pyramid of Glasses time limit per test 1 second memory limit per test 256 megabytes input standard i ...
- forEach用法介绍
array.forEach(callback[, thisArg]) forEach() 方法让数组的每一项都执行一次给定的函数. callback在数组每一项上执行的函数,接收三个参数: curre ...
- Android抓包解析全过程
需求原因 在android开发中,遇到socket编程,无法从log日志中查看到与之通讯的socket发送和返回的数据包是什么,这里介绍一个工具,tcpdump工具和wireshark工具查看抓到的内 ...
- 浅谈h5移动端页面的适配问题
一.前言 昨天唠叨了哈没用的,今天说点有用的把.先说一下响应式布局吧,我一直认为响应式布局的分项目,一下布局简单得项目做响应式还是可以可以得.例如博客.后台管理系统等.但是有些会认为响应式很牛逼,尤其 ...
- apt-get 总结2
本文列举了常用的APT命令参数: apt-cache search package 搜索软件包 apt-cache show package 获取包的相关信息,如说明.大小.版本等 sudo apt ...
- laravel 获取最后一条sql的小函数
function lastSql(){ $sql = DB::getQueryLog(); $query = end($sql); return $query; }
- Nginx配置文件nginx.conf中文详解【转】
PS:Nginx使用有两三年了,现在经常碰到有新用户问一些很基本的问题,我也没时间一一回答,今天下午花了点时间,结合自己的使用经验,把Nginx的主要配置参数说明分享一下,也参考了一些网络的内容,这篇 ...
- QML插件扩展(一)
准备分两节来介绍QML扩展插件,分别为 (一)基于QML文件的扩展方式 (二)基于C++的插件扩展 这篇先介绍基于QML的插件扩展. 先介绍几个基本概念: qmldir: 用于组织自定义的QML插件, ...
- sql server中单引号拼接字符串(书写错误会出现错误"浮点值 XXXX 超出了计算机表示范围(8 个字节)。“XX”附近有语法错误。")
" ' "(单引号)的运用:在sql server中,两个" ' "(单引号)在拼接字符串的情况下运用,就是表示拼接上了一个" ' "单引号 ...