功能简介

DataInputStream和DataOutputStream 继承了各自的FilterInputStream以及FilterOutputStream
使用装饰器模式对InputStream和OutputStream进行功能增强

FilterInputStream以及FilterOutputStream 都是Decorator 抽象的装饰器角色(并不是抽象类)
他们内部都包含了各自需要增强的抽象构建


DataInput         接口用于从二进制流中读取字节,并根据所有 Java 基本类型数据进行重构
DataOutput       
接口用于将数据从任意 Java 基本类型转换为一系列字节,并将这些字节写入二进制流





DataInputStream和DataOutputStream  通过实现DataInput 和DataOut接口
并且借助于装饰器模式,对InputStream和OutputStream的read方法增强出来多个版本
可以读取基本数据类型

DataInputStream

继承自InputStream中的read的两个版本方法
都是直接使用原方法
可以看到,去掉read和个别独有的方法外
其余方法都来自DataInput


而其他的方法都是需要依赖于read的两个版本的方法
比如下面这几个,都是对in.read调用的基础上,进行功能的增强
如果说都不使用in.read方法,那还叫什么装饰器模式


DataOutputStream

write两个版本都来自OutputStream,没有功能增强
flush也是如此,没有增强

不过DataOutputStream 内部有一个计数器,用于记录已经读取的个数
incCount方法用于计数

其余来自DataOutput的方法,都是借助于装饰器模式对于write方法的增强

比如


一定要理解装饰器模式
是你还有你
在使用你的能力的时候,顺便在增强一下,所以内部自然会需要借助于原来的方法


总结:

DataInputStream和DataOutputStream 借助于装饰器模式,继承自他们的FilterXXXoutStream
对InputStream进行功能增强
所有增强出来的功能,来自于DataInput以及DataOutput
这两个接口是用于约定 从二进制字节中读取数据 以及将基本类型数据写入到二进制字节的两个接口
其实如果说要不是别的地方也还是需要DataInput以及DataOutput中的约定的话
这一切完全都可以去掉这两个接口,直接提供readXXX 或者writeXXX方法即可
所以千万不要被DataInput以及DataOutput 迷惑

两条主线:
装饰器模式功能增强
增强的功能来自DataXXXput接口



[十一]JavaIO之DataInputStream 和 DataOutputStream的更多相关文章

  1. Java IO(十一) DataInputStream 和 DataOutputStream

    Java IO(十一) DataInputStream 和 DataOutputStream 一.介绍 DataInputStream 和 DataOutputStream 是数据字节流,分别继承自 ...

  2. DataInputStream和DataOutputStream使用方法细节探讨

    DataInputStream和DataOutputStream都是Java中输入输出流的装饰类,用起来非常方便.今天就来讨论一下使用该类时候遇到的编码问题.  package com.vince ...

  3. java下DataInputStream与DataOutputStream写入数据的同时写入数据类型

    package cn.stat.p2.demo; import java.io.DataInputStream; import java.io.DataOutputStream; import jav ...

  4. 将如下三组不同类型的数据利用DataInputStream和DataOutputStream写入文件,然后从文件中读出

    三组数据如下: {19.99 , 9.99 , 15.99 , 3.99 , 4.99} {12 , 8 , 13 ,29 ,50} {"Java T-shirt" , " ...

  5. Java之IO(四)DataInputStream和DataOutputStream

    转载请注明源出处:http://www.cnblogs.com/lighten/p/6986155.html 1.前言 DataInputStream和DataOutputStream分别继承了Fil ...

  6. java代码----------实现创建DataInputStream和DataOutputStream进行读写

    总结: 主要是 捕获异常 package com.a.b; import java.io.*; public class testData { public static void main(Stri ...

  7. DataInputStream和DataOutputStream

    import java.io.BufferedInputStream; import java.io.BufferedOutputStream; import java.io.ByteArrayInp ...

  8. java io流 数据流 DataInputStream、DataOutputStream、ByteArrayInputStream、ByteArrayOutputStream

    例子程序: package io; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import ...

  9. [二十一]JavaIO之BufferedReader 与 BufferedWriter

    功能简介 BufferedReader  从字符输入流中读取文本,内部缓冲各个字符,从而实现字符.数组和行的高效读取 BufferedWriter 将文本写入字符输出流,内部缓冲各个字符,从而提供单个 ...

随机推荐

  1. 执行grunt命令报错 Cannot find module 'coffee-script'

    Failed to list grunt tasks in yudian-frontend-salesplatform\Gruntfile.js: process finished with exit ...

  2. node05

    1.ejs: const ejs = require('ejs') ejs.renderFile('./template/a.ejs', {name:'cc'}, function (err, dat ...

  3. vi 配置

    vim       ~/.vimrc source    ~/.vimrc 添加相关配置 一直生效 0  行首 $    行尾 spacebar   空格键:         合并多行 spaceba ...

  4. Hibernate4集成spring4报错----No Session found for current thread

    在编写一个Hibernate4集成spring4的小demo的时候出现了该错误: org.hibernate.HibernateException: No Session found for curr ...

  5. Java作业十三(2017-11-20)

    /*使用一位数组解决 1 1 2 3 5 8 13 数列问题 斐波纳契数列 Fibonacci*/ package cn.GM; public class array { public static ...

  6. 别以为真懂Openstack: 虚拟机创建的50个步骤和100个知识点(3)

    四.Nova-compute 步骤17:nova-compute接收到请求后,通过Resource Tracker将创建虚拟机所需要的资源声明占用 步骤18:调用Neutron API配置Networ ...

  7. Vue 学习笔记 — 无法避免的dom操作

    简书 使用Vue了一段时间,感觉确实不错,"数据驱动视图"非常好用,大部分情况下都不需要关心dom,但是凡事都有例外,总有一些时候我们必须要直接对dom进行操作,比如下面这个例子: ...

  8. [Swift]LeetCode342. 4的幂 | Power of Four

    Given an integer (signed 32 bits), write a function to check whether it is a power of 4. Example 1: ...

  9. [Swift]LeetCode435. 无重叠区间 | Non-overlapping Intervals

    Given a collection of intervals, find the minimum number of intervals you need to remove to make the ...

  10. [Swift]LeetCode501. 二叉搜索树中的众数 | Find Mode in Binary Search Tree

    Given a binary search tree (BST) with duplicates, find all the mode(s) (the most frequently occurred ...