装饰模式(旧恋)「建议收藏」

装饰模式(旧恋)

大家好,又见面了,我是全栈君。

|–什么是装饰模式。

装饰模式:是你还是你,一切拜托你(借用老崔经典词)。

它是由继承出现的。先有继承,再有装饰。

回顾继承

    优点:提高复用性,让能够反复使用。通过方法重写利用后期扩展。

    坏处:因为类与类之间的继承关系。但他们关系增强。耦性也就高了。不符合java宗旨:低耦合。高内聚。

对照方下:

a:
有一个Witer体系


|–TxtWrite


|–Mp3Write


|–DIDWrite

上面是一个普通子类实现。调用者认为运行太慢,要求对三者进行增强(高效|缓冲)。改动例如以下

class myBuffereWrite exetends Write{
//接收子类:Fu f = new Zi();
private Write ziWrite;


public BuffereWrite(Write ziWrite)
{
this.ziWrite = ziWrite;
}
public void writeLine(String line)
{
//使用ziWrite进行整容处理。然后一行数据保存到write中。
}
public void close()
{
ziWrite.clese();//多态(调用的还是子类)!
}
public void flash(){
ziWrite.flash();//多态(调用的还是子类)。
}
....//重写Write的抽象方法。调用的myBuffereWrite中的,再方法里边调用是传送ziWrite。

仅仅只是在调用它之前给它做了一些手术。

}

|–总结

   1:比方你使用Write的高效功能,那你就创建myBuffereWrite,传递你的对其高效的对象,比方FileWrite();

   2:装饰模式体现了对一个对象(功能)的增强(高内聚),然后紧密性比較弱(低耦合)。

   3:JDK中用的装饰就挺多的,比方BufferedWriter(Writer out);PrintStream(OutputStream out);ObjectInputStream(InputStream in)等。

|–代码演示样例

  模拟BuffereReader装饰类

package com.Decoration;

import java.io.IOException;
import java.io.Reader;

/**
 * @author hubiao
 * 模拟BuffereReader装饰类
 *	
 *	分析:模拟一个类,就是自定一个类。实现它的特有方法:ReadLine();
 * 	  1:模拟什么:特有方法
 *        2:你有什么:依据装饰特点。自定的类继承一个抽象类,由于BuffereReader的readLine底层也是继承Reader中的。

* 我们要做的。也是继承Reader,写一个与BuffereReader一样的ReadLine方法来。 */public class MyBuffere extends Reader { /*Reader是一个抽象类的父类。将须要高效的类都实现了它。

都是它的子类。

*/ private Reader reader = null; public MyBuffere(Reader reader){ this.reader = reader; } public int read(char[] cbuf, int off, int len) throws IOException { return reader.read(cbuf, off, len); } public String readLine() throws IOException { /** * 1:这里要思考,使用 * A:read(char[] cbuf, int off, int len);一次读取一缓冲区 * B:read();//一次读取一个字符串 * 2:分析 * 我们模拟readLine目的是为了模拟什么?还不是为了实现BufferedReader中的readerLine一次读取一行的高效方法。 * 然后使用A方法不合适,由于它一次读取一个char容量定义的长度,我们封装好的代码非常难获知调用者要读取的数据文本的每行数据有多长。

* 使用B方法的优点,是一次读取一个字符,当遇到\r\n就说明是一行的结束。则说一行读取完成,那怎么一行的数据每一个字符用什么保存呢? * 使用String, 这...太可怕了吧。由于我们知道String在java中是一个常量池。

一但赋值,将不可变。

所以选择效率高的StringBuilder * 把每一个字符拼接到StringBuffer中。再返回给调用者。 */ //单字符容器 StringBuffer buffer = new StringBuffer(); //每一个字符 int read = 0; while((read = reader.read())!=-1) { char chr = (char) read; if(chr=='\r') continue; if(chr=='\n') return buffer.toString(); else buffer.append(chr); } //防止读取的是最后一行。则没有\r\n。那么再推断缓冲区中是否有值?假设有,则再返回。 if(buffer.length() > 0 ) return buffer.toString(); else return null; } public void close() throws IOException { reader.close(); }}


  模拟LineNumberReader

/**
 * @author hubiao
 *	模拟LineNumberReader
 *		也是相同,模拟,就是自定一个类,模拟需求给出的特殊方法:获取每一个行号,然后读取每一行。
 */
public class MyLineNumberReader extends Reader{

	/*接收传递子类对象,Fu f = new Zi();//多态*/
	private Reader reader;
	
	private int lineNumber;//行号
	
	public MyLineNumberReader(Reader reader) {
		this.reader = reader;
	}

	public int read(char[] cbuf, int off, int len) throws IOException {
		return reader.read(cbuf, off, len);
	}
	
	public String readLine() throws IOException
	{
		//单字符容器
		StringBuffer buffer = new StringBuffer();
		
		//每一个字符
		int read = 0;
		while((read = reader.read())!=-1)//-1表示读取到流的结尾!
		{
			char chr = (char) read;
			if(chr=='\r')
				continue;
			if(chr=='\n'){
				lineNumber++;
				return buffer.toString();
			}
			else
				buffer.append(chr);
		}
		
		//防止读取的是最后一行,则没有\r\n。那么再推断缓冲区中是否有值?假设有,则再返回。

if(buffer.length() > 0 ){ lineNumber++; return buffer.toString(); }else return null; } public void close() throws IOException { reader.close(); } public int getLineNumber() { return lineNumber; } public void setLineNumber(int lineNumber) { this.lineNumber = lineNumber; }}

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/115396.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • 分布式事务解决方案之TCC(Hmily)「建议收藏」

    分布式事务解决方案之TCC(Hmily)「建议收藏」1什么是TCC事务TCC是Try、Confirm、Cancel三个词语的缩写,TCC要求每个分支事务实现三个操作:预处理Try、确认Confirm、撤销Cancel。Try操作做业务检查及资源预留,Confirm做业务确认操作,Cancel实现一个与Try相反的操作即回滚操作。TM首先发起所有的分支事务的try操作,任何一个分支事务的try操作执行失败,TM将会发起所有分支事务的Cancel操作,若try操作全部成功,TM将会发起所有分支事务的Confirm操作,其中Confirm/Cancel操作若执

  • vue项目封装组件_前端组件封装

    vue项目封装组件_前端组件封装前言在使用vue进行日常开发的时候,组件的封装是一个很常规的操作,也可以从npm仓库下载别人封装好的组件来使用,比如iview,elementui等…但每个项目的应用场景不同,所以我们有时也需要自己封装组件。而如果在开发中换了项目,那么就只能复制代码过去,略显麻烦,这个时候呢,可以将封装好的组件上传到npm仓库,需要使用时就可以直接通过npm指令下载,非常方便。1.环境准备因为我们封装的是Vue组件,所以直接在脚手架中封装即可。//创建项目因为我们只需封装组件所以RouterSt

  • idea打包操作_idea package打包

    idea打包操作_idea package打包前言:IDEA导出war包的方式与MyEclipse有一点不同,使笔者在使用的时候有点困惑,在网上查阅相关资料的时候,发现都讲解得都不是非常的清晰,于是有了这篇随笔的诞生。话不多说,直接进入正题。1.进入项目的ProjectStructure界面,进行如下4步操作。2.通过上述4步操作后,进入如下界面。 注:1.修改war包的名称(根据实际情况);2.如果出现WEB-INF文件夹则删除,否则不做…

  • Java取余和取模

    Java取余和取模抛开高级语言的实现,取余运算和取模运算本身并不完全一致,区别在于对负整数进行取商时操作不同。虽然这样说,但是取余运算和取模运算的公式都一样。对于x和y两个整数(int),通过以下两个操作获取余数或模数:step1、求商:intz=x/ystep2、求余数或模数:intresult=x-y*z它们的差别在于,如果z的值…

  • STM32中重定向printf到SWO口[通俗易懂]

    STM32中重定向printf到SWO口[通俗易懂]Keil中调试:用SWO功能替代printf引用网址:http://blog.csdn.net/xiaolei05/article/details/8526021嵌入式软件开发中的一个基本需求就是能通过终端来输出调试信息,一般可通过2种方式实现:一种是使用串口线连接板上的UART和PC上的COM口,通过PC上的超级终端来查看调试信息;另一种则是采用半主机机制,但有可能不被

  • idea激活码2019破解方法[通俗易懂]

    idea激活码2019破解方法,https://javaforall.cn/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号