Java之IO流基础流对象
import java.io.FileWriter;
import java.io.IOException; public class IODemo { private static final String LINE_SPEARATOR = System.getProperty("line.separator"); /**
* @param args
* @throws IOException
*/
public static void main(String[] args) throws IOException {
/**
* 创建一个可以往文件中写入字符数据的字符输出流对象
* 既然是往一个文件中写入文字数据,那么在创建对象时,就必须明确该对象文件(用于存储数据的目的地)
* 如果文件不存在,则创建。
* 如果文件存在,则覆盖
*
* 如果构造函数中加入ture,可以实现文件的续写。
*/
FileWriter wf = new FileWriter("E:\\Workspaces\\MyEclipse 10\\a.txt",true);
/**
* 调用Writer对象中的writer(String s)方法,写入数据。
* 其实数据写入到临时存储缓冲区中。
*/
wf.write("my data"+LINE_SPEARATOR+"again line "); /**
* 进行刷新,将数据直接写到目的地中。
*/
wf.flush();
/**
* 关闭流,关闭资源。在关闭前会调用flush刷新缓冲中的数据到目的地中。
* 如果在关闭流后再进行flush方法的调用,则会导致IOException
* 如需要继续写入,则使用flush进行数据写入,如果不需要再写数据则直接调用close即可。
*
*/
wf.close();
}
}
import java.io.FileReader;
import java.io.IOException; public class FileReaderDemo1 { /**
* @param args
* @throws IOException
*/
public static void main(String[] args) throws IOException {
// 1,创建一个能够读取字符流数据的流对象
/**
* 在创建读取刘对象时,必须要明确被读取的文件,一定要确定该文件是存在的。
*
* 用一个读取流关联一个已存在的文件。
*/
FileReader fr = new FileReader("E:\\Workspaces\\MyEclipse 10\\a.txt");
/**
* 用reader中的read方法读取
* 简单读取,一个字符一个字符的读。
*/ int ch = 0;
while((ch=fr.read())!=-1){
System.out.println((char)ch);
} fr.close();
} }
import java.io.FileReader;
import java.io.IOException; public class FileReaderDemo2{ /**
* @param args
* @throws IOException
*/
public static void main(String[] args) throws IOException {
FileReader fr = new FileReader("E:\\Workspaces\\MyEclipse 10\\a.txt");
/**
* 使用read(char[] ch)读取文本文件数据。
* 先创建字符数组
*/
char[] buf = new char[1024];
int len = 0; while((len = fr.read(buf))!=-1){//将读到的字符存储到数组中。
System.out.println(new String(buf));
}
fr.close();
} }
import java.io.FileReader;
import java.io.FileWriter;
import java.io.IOException; public class CopyTextDemo { private static final int BUFFER_SIZE = 1024; /**
* @param args
*/
public static void main(String[] args) {
FileReader fr = null;
FileWriter fw = null; try {
fr = new FileReader("E:\\Workspaces\\MyEclipse 10\\a.txt");
fw = new FileWriter("E:\\Workspaces\\MyEclipse 10\\b.txt");
//创建一个临时容器,用于缓存读取到的字符
char[] buf = new char[BUFFER_SIZE];
//定义一个变量记录读取到的字符数其实就是往数组里装的字符个数。
int len = 0;
while((len = fr.read(buf))!= -1){
fw.write(buf,0,len);
}
} catch (Exception e) {
throw new RuntimeException("失败了");
}finally{
if(fw!=null){
try {
fw.close();
} catch (IOException e) {
e.printStackTrace();
}
}
if(fr!=null){
try {
fr.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
} }
import java.io.BufferedWriter;
import java.io.FileWriter;
import java.io.IOException; public class BufferedWriterDemo { /**
* @param args
* @throws IOException
*/
public static void main(String[] args) throws IOException {
FileWriter fw = new FileWriter("E:\\Workspaces\\MyEclipse 10\\b.txt");
//为了提高写入的效率,使用了字符流的缓冲区。
//创建了一个字符写入流的缓冲区对象,并和指定要被缓冲的流对象相关联
BufferedWriter bufw = new BufferedWriter(fw);
//使用缓冲区的写入方法将数据先写入到缓冲区中
bufw.write("buffered write");
bufw.newLine();
bufw.write("again line");
//使用缓冲区的刷新方法将数据刷到目的地中。
bufw.flush(); //关闭缓冲区。其实关闭的就是被缓冲的流对象。
bufw.close(); } }
FileReader fr = new FileReader("E:\\Workspaces\\MyEclipse 10\\a.txt");
BufferedReader bufr = new BufferedReader(fr);
String line = null;
while((line=bufr.readLine())!=null){
System.out.println(line);
}
import java.io.FileReader;
import java.io.IOException; public class MyBufferedReader { /**
* @param args
* 自定义的读取缓冲区,模拟一个BufferedReader.
* 分析:
* 缓冲区中无非就是封装了一个数组,
* 并对外提供了更多的方法对数组进行访问,
* 其实这些方法最终操作的都是数组的角标
*
* 缓冲的原理:
* 其实就是从源中获取一批数据装进缓冲区中
* 在从缓冲区中不断的取出一个一个数据。
*
* 当此次取完后,再从源中继续取一批数据进缓冲区。
* 当源中的数据取光时,用-1作为结束标记。
*
*/
private FileReader r;
private char[] buf = new char[1024];//定义一个数组作为缓冲区 //定义一个指针用于操作这个数组中的元素,当操作到最后一个元素后,指针应该归零。
private int pos = 0; //定义一个计数器,用于记录缓冲区中的数据个数。当该数据减到0,就从源中继续获取数据到缓冲区中。
private int count = 0; MyBufferedReader(FileReader r){
this.r = r;
}
/**
* 该方法从缓冲区中一次取一个字符
* @return
* @throws IOException
*/
public int myRead() throws IOException{
//从源中获取一批数据到缓冲区中。需要先做判断,只有计数器为0时,才需要从源中获取数据。 /*if(count==0){
count = r.read(buf);
if(count<0){
return -1;
}
pos = 0;//每次获取数据到缓冲区后,角标归0
char ch = buf[pos];
pos++;
count--;
return ch;
}else if(count>0){
char ch = buf[pos];
pos++;
count--;
return ch;
}
*/
//方法简化重写
if(count==0){
count = r.read(buf);
pos = 0;
}
if(count<0){
return -1;
}
char ch = buf[pos];
pos++;
count--;
return ch;
} public String myReadLine() throws IOException{
StringBuilder sb = new StringBuilder();
int ch = 0;
while((ch = myRead())!=-1){
if(ch == '\r'){
continue;
}
if(ch == '\n'){
return sb.toString();
}
//将从缓冲区中读到的字符存储到缓存行数据的缓冲区中。
sb.append((char)ch);
}
if(sb.length()!=0){
return sb.toString();
}
return null;
}
}
import java.io.IOException;
import java.io.Reader; public class MyBufferedReader extends Reader { private Reader r;
private char[] buf = new char[1024];
private int pos = 0;
private int count = 0; MyBufferedReader(Reader r){
this.r = r;
} public int myRead() throws IOException{
if(count==0){
count = r.read(buf);
pos = 0;
}
if(count<0){
return -1;
}
char ch = buf[pos];
pos++;
count--;
return ch;
} public String myReadLine() throws IOException{
StringBuilder sb = new StringBuilder();
int ch = 0;
while((ch = myRead())!=-1){
if(ch == '\r'){
continue;
}
if(ch == '\n'){
return sb.toString();
}
sb.append((char)ch);
}
if(sb.length()!=0){
return sb.toString();
}
return null;
}
@Override
public int read(char[] cbuf, int off, int len) throws IOException { return 0;
}
@Override
public void close() throws IOException {
r.close();
} }
Java之IO流基础流对象的更多相关文章
- Java I/O— 梳理各种“流”
背景 Java核心库java.io它提供了一个综合IO接口.包含:文件读写.标准装备输出等..Java在IO它是流为基础进行输入输出的.全部数据被串行化写入输出流,或者从输入流读入. -- 百度百科 ...
- Java之IO(一)InputStream和OutputStream
转载请注明源出处:http://www.cnblogs.com/lighten/p/6964702.html 1.前言 计算机的IO操作一直都是比较重要的一环,IO顾名思义,就是输入输出流.不管是磁盘 ...
- Java 中级IO流基础及主要API编程
1. IO流基础知识,流 是字节从源到目的地的运行的轨迹,次序是有意义的, 字节会按照次序进行传递, 比如Hello World 在下图中的传递的轨迹.该图形象的解释了IO中流的概念.流中全是字节.2 ...
- Java IO 文件与流基础
Java IO 文件与流基础 @author ixenos 摘要:创建文件.文件过滤.流分类.流结构.常见流.文件流.字节数组流(缓冲区) 如何创建一个文件 #当我们调用File类的构造器时,仅仅是在 ...
- JAVA IO分析二:字节数组流、基本数据&对象类型的数据流、打印流
上一节,我们分析了常见的节点流(FileInputStream/FileOutputStream FileReader/FileWrite)和常见的处理流(BufferedInputStream/B ...
- Java 基础 IO流(转换流,缓冲)
一,前言 在学习字符流(FileReader.FileWriter)的时候,其中说如果需要指定编码和缓冲区大小时,可以在字节流的基础上,构造一个InputStreamReader或者OutputStr ...
- java:IO流(处理流(缓冲流,转换流,数据流),对象的序列化,Properties)
字节缓冲流:(BufferedInputStream,BufferedOutStream) *按照流的功能来分:节点流和处理流 *节点流可以直接操作数据源: *InputStream *--FileI ...
- Java:IO流其他类(字节数组流、字符数组流、数据流、打印流、Properities、对象流、管道流、随机访问、序列流、字符串读写流)
一.字节数组流: 类 ByteArrayInputStream:在构造函数的时候,需要接受数据源,而且数据源是一个字节数组. 包含一个内部缓冲区,该缓冲区包含从流中读取的字节.内部计数器跟踪 read ...
- Java基础知识强化之IO流笔记38:字符流缓冲流之BufferedWriter / BufferedReader使用
1. 字符流缓冲流: 字符流为了高效读写,也提供了对应的字符缓冲流. BufferedWriter:字符缓冲输出流 BufferedReader:字符缓冲输入流 2. BufferedWriter使用 ...
随机推荐
- 采用curl库
Windows通过使用curl库: 到http://curl.haxx.se/下了个curl的源代码下来,源代码是用VC6编译的,我在VS2005下又一次进行编译.竟然仅仅有一个警告. cUrl的实现 ...
- HDU 1596 find the safest road (最短路)
find the safest road Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Ot ...
- SSH深度历险记(八) 剖析SSH核心原则+Spring依赖注入的三种方式
于java发育.一类程序猿必须依靠类的其他方法,它是通常new依赖类的方法,然后调用类的实例,这样的发展问题new良好的班统一管理的例子.spring提出了依赖注入的思想,即依赖类不由程 ...
- ecshop广告调用方法
在简单地概括ecshop广告调用该方法,已发表在博客上,在这里,我们总结了以下 :就是官方默认的方法.先加入广告位,然后加入模板的广告位区域,再在将两者相应上. 1.后台 > 广告管理 > ...
- Team Foundation Server 2015使用教程--团队项目创建
- 【C++ Primer每天刷牙】一间 迭代器
迭代器的介绍 概述 迭代器是一种检查容器内元素并遍历元素的数据类型. 迭代器(iterator)是一种对象,它能够用来遍历标准模板库容器中的部分或所有元素,每一个迭代器对象代表容器中的确定的地址.迭代 ...
- avalonjs1.5 入门教程
迷你MVVM框架 avalonjs1.5 入门教程 avalon经过几年以后,已成为国内一个举足轻重的框架.它提供了多种不同的版本,满足不同人群的需要.比如avalon.js支持IE6等老旧浏览器,让 ...
- Oracle 实现 mysql 的 find_in_set 排序!
oracle 实现类似MYSQL的 find_in_set 排序,函数 decode: select * from tb_info_game where gameid in(23,20,19,26,1 ...
- 【智能家居篇】wifi网络访问原理(下一个)——联想Association
转载请注明出处:http://blog.csdn.net/Righthek 谢谢! 认证完毕后,下一步就是关联(Association). 工作站与基站进行关联.以便获得网络的全然訪问权. 关联属于一 ...
- Swift——(两)Swift访问元组
在Swift在,获取元组的值到一个位置,通过三种方法: 1.使用元组变量/常量 @Author: twlkyao转载或者引用请保留此行. let http404Error = (404, &q ...