Java容器的概要

简介:
【Java流输入/输出原理】
在Jaav程序。对于输入数据/输出操作"流"(stream)时尚;J2SDK它提供了多种


各种各样的"流"类,用于获得不同类型的数据;程序通过标准方法输入或输出数据。


【输入/输出流的分类】
java.io包中定义了多个刘类型(累活抽象类)来实现输入/输出功能;能够从不同的角度


对其进行分类:
 按数据流的方向不同能够分为输入流和输出流。
 案处理数据单位不同能够分为字节流和字符流。
 依照功能不同能够分为节点刘和处理流。
J2SDK所提供的全部流类型位于包java.io内都分别继承自下面四种抽象流类型。

|------------------------------------|
|        |     字节流    |   字符流  |
|--------|---------------|-----------|
| 输入流 |  InputStream  |   Reader  |
|--------|---------------|-----------|
| 输出流 | OutputStream  |   Writer  |
|------------------------------------|


【节点流和处理流】
节点流为能够从一个特定的数据源(节点)读写数据(如:文件。内存)。
处理流是"链接"在已存在的流(节点流和处理流)智商,通过对数据的处理为程序提供更


为强大的读写功能。


【InputStream的基本方法】
//读取一个字节并以证书的形式返回(0~255),
//假设返回-1已到输入流的末尾
int read() throws IOException


//读取一系列字节并存储到一个数组buffer,
//反hi十几度去的字节数。假设读取前已到输入流的末尾返回-1
int read(byte[] buffer) throws IOException


//读取length个字节
//并存储到一个字节数组buffer,从length位置開始
//返回十几度去的字节数,假设读取前已到输入流的末尾返回-1
int read(byte[] buffer,int offset,int length) throws IOException


//关闭流释放内存资源
void close() throws IOException


//跳过n个字节不读。返回时机跳过的字节数
long skip(long n) throws IOException


【OutputStream的基本方法】
//向输出流中写入一个字节数据,该字节数据为參数b的低8位
void write(int b) throws IOException


//将一个字节类型的数组中的数据写入输出流
void write(byte[] b) throws IOException


//讲一个字节类型的数组中的从指定位置(off)開始的
//len个字节写入到输出流
void write(byte[] b,int off,int len) throws IOException


//关闭释放内存资源
void close() throws IOException


//将输出流中缓冲的数据所有写出到目的地
void flush() throws IOException
【Reader的基本方法】
//读取一个字符并一整数的形式返回(0~255)
//假设返回-1已到输入流的末尾
int read() throws IOException


//读取length个字符
//并存储到一个数组buffer,从length位置開始
//返回十几度去的字符数,假设读取前已到输入流的末尾返回-1
int read(char[] cbuf,int offset,int length) throws IOException


//关闭流释放内存资源
void close() throws IOException


//跳过n个字符不读,返回时机条股的字节数
long skip(long n) throws IOException
【Writer的基本方法】
//想输出流中写入一个字符数据,该字符数据为參数b的低16位
void write(int c) throws IOException


//将一个字符类型的数组中的数据写入输出流
void write(char[] cbuf) throws IOException


//将一个字符类型的数组总的从指定位置(offset)開始的
//length个字符写入到输出流
void write(char[] cbuf,int offset,int length) throws IOException


//关闭释放内存资源
void close() throws IOException


//将输出流中缓冲的数据所有写出到目的地
void flush() throws IOException
【訪问文件】
FileInputStream 和 FileOutputStream 分别继承自 InputStream 和 OutputStream用


于向文件里输入和输出字节。
FileInputStream和FileOutputStream的经常使用构造方法:
 FileInputStream(String name) throws FileNotFoundException
 FileInputStream(File file) throws FileNotFoundException
 FileOutputStream(String name) throws FileNotFoundException
 FileOutputStream(File file) throws FileNotFoundException
 FileOutputStream(File file,boolean append) throws FileNotFoundException
FileInputStream 和 FileOutputStream 类支持其父类InputStream 和 OutputStream 


所提供的数据读写方法。


注意:
 在实例化FileInputStream和FileOutputStream流时要用try-catch语句已处理其可能抛


出的FileNotFoundException。
 在读写数据时也要用try-catch语句以处理可能抛出的IOException。
 FileNotFoundException是IOException的子类。


【缓冲流】
缓冲流要“套接”在对应的节点刘之上。对读写的数据提供了缓冲的功能,提高了读写


的效率。同一时候添加了一些新的方法。
J2SDK提供了四种缓冲流,其经常使用的构造方法为:
BufferedReader(Reader in)
BufferedReader(Reader in,int sz) //sz为自己定义缓冲区的大小
BufferedWriterWriter(Writer out)
BufferedWriter(Writer out,int sz)
BufferedInputStream(InputStream in)
BufferedInputStream(InputStream in,int size)
BufferedOutputStream(OutputStream out)
BufferedOutputStream(OutputStream out,int size)
缓冲区输入流支持其父类的mark和reset方法。
BufferReader提供了readLine方法用于读取一行字符串(以\r或\n分隔)。
BufferedWriter提供了newLine用于写入一个行分隔符。
对于输出的缓冲流,写出的数据会如今内存中缓存,使用flush方法将会使内存中的数据


立马写出。


【转换流】
InputStreamReader和OutputStreamWriter用于字节数据到字符数据之间的转换。
InputStreamReader须要和InputStream“套接”。


OutputStreamWriter须要和OutputStream“套接”。


转换流在构造时能够指定其编码集合,比如:
InputStream isr = new InputStreamReader(System.in , "ISO8859_1")
【数据流】
DataInputStream 和 DataOutputStream 分别继承自InputStream 和 OutputStream,它


属于处理流。须要分别“套接”在InputStream和OutputStream类型的节点流上。
DataInputStream 和 DataOutputStream提供了能够存取与机器无关的Java原始类型数据


(如:int,double等)的方法。


DataInputStream和DataOutputStream的构造方法为:
  DataInputStream(InputStream in)
  DataOutputStream(OutputStrewam out)
【Print流】
PrintWriter和PrintStream都属于输出流,分别针对于字符和字节。
PritnWriter和PritnStream提供了重载的print
Println方法用于多种数据的输出。
PrintWriter和PrintStream的输出操作不会抛出异常。用户通过检測错误状态获取错误


信息。
PrintWriter和PrintStream有自己主动flush功能。
 PrintWriter(Writer out)
 PrintWriter(Writer out,boolean autoFlush)
 PrintWriter(OutputStream out)
 PrintWriter(OutputStream out,boolean autoFlush)
 PrintStream(OutputStream out)
 PrintStream(OutputStream out,boolean autoFlush)
【Object流】
直Object写或读出
 transientkeyword
 serializable接口
 externalizable接口





本文转自mfrbuaa博客园博客,原文链接:http://www.cnblogs.com/mfrbuaa/p/5040997.html,如需转载请自行联系原作者


相关文章
|
2月前
|
Java 虚拟化 容器
(Java)Java里JFrame窗体的基本操作(容器布局篇-1)
容器 容器,我的理解是可以包容其他东西的玩意。它可以是一个盒子,可以是一个虚拟化的物品,可只要能包裹住其他存在质体的东西,那么都可以称作是容器。例如:JPanel组件和JScollPane组件两者都是容器也是组件。 既然有容器,那么容器中的布局就必不可少了。不然不规矩的摆放物品,人类看不习惯,我也看不习惯 ???? 本篇内容,将说明java JFrame窗体里容器中几类布局。 说明:所有在JFrame窗体里的容器布局都会使用setLayout()方法,采用的布局参数都将放进这个方法里 绝对布局 调用窗体容器
118 1
|
6月前
|
存储 缓存 安全
Java 集合容器常见面试题及详细解析
本文全面解析Java集合框架,涵盖基础概念、常见接口与类的特点及区别、底层数据结构、线程安全等内容。通过实例讲解List(如ArrayList、LinkedList)、Set(如HashSet、TreeSet)、Map(如HashMap、TreeMap)等核心组件,帮助读者深入理解集合容器的使用场景与性能优化。适合准备面试或提升开发技能的开发者阅读。
120 0
|
6月前
|
缓存 Java API
Java 集合容器实操技巧与案例详解
本教程基于Java 8+新特性和现代开发实践,深入讲解Java集合容器的实操技巧。通过具体场景演示Stream API数据处理、ConcurrentHashMap并发控制、LinkedHashMap实现LRU缓存、TreeSet自定义排序等高级特性。同时涵盖computeIfAbsent优化操作、EnumMap专用集合使用、集合统计与运算(交集、并集、差集)等内容。代码示例丰富,助力掌握高效编程方法。[点击获取完整代码](https://pan.quark.cn/s/14fcf913bae6)。
89 0
|
Kubernetes Cloud Native Java
云原生之旅:从容器到微服务的演进之路Java 内存管理:垃圾收集器与性能调优
【8月更文挑战第30天】在数字化时代的浪潮中,企业如何乘风破浪?云原生技术提供了一个强有力的桨。本文将带你从容器技术的基石出发,探索微服务架构的奥秘,最终实现在云端自由翱翔的梦想。我们将一起见证代码如何转化为业务的翅膀,让你的应用在云海中高飞。
|
10月前
|
存储 安全 算法
Java容器及其常用方法汇总
Java Collections框架提供了丰富的接口和实现类,用于管理和操作集合数据。
191 2
Java容器及其常用方法汇总
|
Java Linux Maven
java依赖冲突解决问题之容器加载依赖jar包如何解决
java依赖冲突解决问题之容器加载依赖jar包如何解决
|
11月前
|
监控 Java 中间件
8G的容器Java堆才4G怎么就OOM了?
本文记录最近一例Java应用OOM问题的排查过程,希望可以给遇到类似问题的同学提供参考。
|
存储 安全 Java
Java多线程编程中的并发容器:深入解析与实战应用####
在本文中,我们将探讨Java多线程编程中的一个核心话题——并发容器。不同于传统单一线程环境下的数据结构,并发容器专为多线程场景设计,确保数据访问的线程安全性和高效性。我们将从基础概念出发,逐步深入到`java.util.concurrent`包下的核心并发容器实现,如`ConcurrentHashMap`、`CopyOnWriteArrayList`以及`BlockingQueue`等,通过实例代码演示其使用方法,并分析它们背后的设计原理与适用场景。无论你是Java并发编程的初学者还是希望深化理解的开发者,本文都将为你提供有价值的见解与实践指导。 --- ####
|
消息中间件 NoSQL Kafka
Flink-10 Flink Java 3分钟上手 Docker容器化部署 JobManager TaskManager Kafka Redis Dockerfile docker-compose
Flink-10 Flink Java 3分钟上手 Docker容器化部署 JobManager TaskManager Kafka Redis Dockerfile docker-compose
375 4
|
Kubernetes Cloud Native 流计算
Flink-12 Flink Java 3分钟上手 Kubernetes云原生下的Flink集群 Rancher Stateful Set yaml详细 扩容缩容部署 Docker容器编排
Flink-12 Flink Java 3分钟上手 Kubernetes云原生下的Flink集群 Rancher Stateful Set yaml详细 扩容缩容部署 Docker容器编排
373 3