IO流知识点
如何判断是输入还是输出?
答:以程序为中心。
如何判断是解码还是编码?
答:以程序为中心。程序只懂二进制,所以,以二进制转换成字符是解码,字符转换成二进制是编码。
1.
首先,File 它是给程序跟文件或文件夹建立的一个联系。它不是代表那个路径下的文件,只是一个联系。不能对文件进行操作。而且也不能判断该文件是否存在。。
File file=new File(path);
如:File file=new File("E:/text/a.jpg");
这行代码说的是:file给程序跟该目录下的文件a.jpg建立了一个联系。但是不能对文件进行操作。
(File 类的实例是不可变的;也就是说,一旦创建,File 对象表示的抽象路径名将永不改变。)---来自jdk
2. InputStream-->FileInputStream
摘自jdk-->
public class FileInputStream extends InputStream
由此可知:
①、FileInputStream 是继承了InputStream抽象类。
②、FilterInputStream 包含其他一些输入流,它将这些流用作其基本数据源,它可以直接传输数据或提供一些额外的功能。FilterInputStream 类本身只是简单地重写那些将所有请求传递给所包含输入流的 InputStream 的所有方法。FilterInputStream 的子类可进一步重写这些方法中的一些方法,并且还可以提供一些额外的方法和字段。
OutputStream-->FileOutputStream跟InputStream-->FileInputStream是一样的
2.(字节流)输入流、输出流的使用步骤:
①、建立联系:File file=new File(path);//跟文件建立一个联系
②、选择流:选择你需要的流,你是要输入流还是输出流。。如:InputStream-->FileInputStream /OutputStream-->FileOutputStream
③、操作:进行输入内容或者输出内容。
④、释放资源:关闭输入流或输出流。如果是输出流,要多写一个flush();强制刷新出去。
简单例子:
输入流:
1 package com.IO;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.io.InputStream;
/**
* 1.建立联系 File对象
* 2.选择流
* 3.操作
* 4.释放资源
* @author Administrator
*
*/
public class Demo01 {
public static void main(String[] args) {
File file=new File("f:/a.txt");//建立联系
InputStream is=null;//提升变量作用域,也就是让变量的作用域变大
if(file.exists()){
try {
is=new FileInputStream(file);
byte[] car=new byte[10];//缓冲数组
int len=0;//实际读取的大小
while(-1!=(len=is.read(car))){
String info=new String(car,0,len);
System.out.println(info);
}
} catch (FileNotFoundException e) {
System.out.println("文件找不到");
} catch (IOException e) {
System.out.println("读取文件失败");
}finally{
if(null!=is){
try {
is.close();
} catch (IOException e) {
System.out.println("关闭输入流失败");
}
}
}
}else{
try {
boolean flag=file.createNewFile();
System.out.println(flag?"成功":"失败");
} catch (IOException e) {
System.out.println("创建文件错误");
}
} }
} 输出流:
package com.IO;
import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.OutputStream;
public class Demo02 {
public static void main(String[] args) {
File file=new File("f:/a.txt");
OutputStream out=null;//提升变量作用域,也就是让变量的作用域变大
if(file.exists()){
try {
out=new FileOutputStream(file);
String str="very good!!! \r\n";
byte[] b=str.getBytes();//字符转换成字节数组
out.write(b);
out.flush();//强制刷新出去
} catch (FileNotFoundException e) {
System.out.println("文件没找到");
} catch (IOException e) {
System.out.println("输出内容发生错误");
}finally{
if(null!=out){
try {
out.close();
} catch (IOException e) {
System.out.println("关闭输出流失败");
}
}
}
}else{
System.out.println("文件不存在!");
}
}
}
IO流知识点的更多相关文章
- IO流知识点总结
IO流的使用:(Input OutPut) 输入输出流: 输入:将文件读到内存中 输出:将文件从内存输出到其他地方 IO技术的作用: 主要就是解决设备和设备之间的数据传输问题.比如: ...
- java IO流知识点总结
I/O类库中使用“流”这个抽象概念.Java对设备中数据的操作是通过流的方式.表示任何有能力产出数据的数据源对象,或者是有能力接受数据的接收端对象.“流”屏蔽了实际的I/O设备中处理数据的细节.IO流 ...
- 2018.4.13 用java配置/生成Xml文件 结合IO流知识点
自己创建本地文件Hello.txt 里面有数据 小明/23/增城/广东 小花/12/浦东/上海 StudentManager.java package com.lanqiao.dmeo7; impor ...
- Java阶段性测试--知识点:数组,面向对象,集合、线程,IO流
#Java基础测试 涉及知识点:数组,面向对象,重载,重写,继承,集合,排序,线程,文件流 一.多项选择题(可能是单选,也可能是多选) 1.下列标识符命名不合法的是( D ). A.$_Name ...
- java中IO流相关知识点
(一) 下边使用outputStream字节输出流进行写操作 package zdbIO;import java.io.File;import java.io.FileNotFoundExceptio ...
- java IO流部分知识点
IO流部分 IO流常用的有:字符流.字节流.缓冲流.序列化流.RandomAccessFile类等 1.字节流 FileInputStream/FileOutputStream BufferedInp ...
- 二十一、Java基础--------IO流之综合案例分析
前三篇文章详细介绍了IO流体系所涉及的重点内容,为了帮助理解与学习,本片博客主要是分析一个与IO操作相关的题目. 例1:在我们观看视频时经常要关注的就是视频的时间长度,在学习了IO操作之后,就可以自己 ...
- 线程+IO流
第十八天知识点总结 线程的停止: 1.停止一个线程,一般是通过一个变量来控制. 2.如果需要停止一个处于一个等待状态的线程,那么需要配合interrupt方法来完成 守护线程(后台线程):在一个进程中 ...
- IO流详解(半教材类型)
这两天学习了IO流,整理了一些理论知识点,仅供参考. java流概述 一 流 从操作系统层面和文件系统,数据保存相关的是所有语言都具备的一个基本功能,java专门开发了一个包:java.io.*;ja ...
随机推荐
- P1242 新汉诺塔
题目描述 设有n个大小不等的中空圆盘,按从小到大的顺序从1到n编号.将这n个圆盘任意的迭套在三根立柱上,立柱的编号分别为A.B.C,这个状态称为初始状态. 现在要求找到一种步数最少的移动方案,使得从初 ...
- Java 虚拟机类加载机制
看到这个题目,很多人会觉得我写我的java代码,至于类,JVM爱怎么加载就怎么加载,博主有很长一段时间也是这么认为的.随着编程经验的日积月累,越来越感觉到了解虚拟机相关要领的重要性.闲话不多说,老规矩 ...
- [bzoj] 3343 教主的魔法 || 带修改分块
原题 长度为n的序列,有两种操作: 1.[l,r]区间每个数+w 2.询问[l,r]区间有多少个数>c 记录lazy数组即可. #include<cstdio> #include&l ...
- Gcd反应堆 (pgcd)
Gcd反应堆 (pgcd) 题目描述 不知什么时候起,TA突然对gcd产生了浓厚的兴趣,于是他为此编写了个程序,输入分别不大于m,n (1<m,n<=10^7)的两个数,就能得出gcd(m ...
- 双系统Ubuntu 无 启用wifi选项
安装好双系统进入ubuntu(14.04)后发现只能用有线连接,不能用wifi.网络连接里无启用wifi选项. 1.查询网卡型号,发现是BCM43132 命令: lspci | grep -i n ...
- Python之Excel编程
excel编程:excel中是unicode编码方式 需要使用xrld,xlwt和openpyxl这三个模块,需先通过pip install下载 xlrd 读取模块:xls,xlsx ...
- jenkins 自定义主题
一.概述 jenkins更新后,页面css布局都已改变,我现在用的jenkins.css, ( png图片需自定义) #page-body { background-image:url(http:// ...
- A simple greedy problem(hdu 4976)
题意:有n个小兵,每个小兵有a[i]血量,第一个人每次只能对一个小兵砍一滴血,第二个人每次对所有生存的小兵砍一滴血. 最后看第一个人最多可以砍杀几个小兵. /* 首先,如果所有小兵的血量都不同的话,我 ...
- Topcoder SRM 601 div1题解
日常TC计划- Easy(250pts): 题目大意:有n个篮子,每个篮子有若干个苹果和橘子,先任取一个正整数x,然后从每个篮子中选出x个水果,把nx个水果放在一起,输出一共有多少种不同的组成方案.其 ...
- 51Nod 1558 树中的配对
题目链接 分析: 想了好久~~~还是得看题解...QwQ 首先因为是排列,所以我们猜想要把式子拆开来看, $ \sum dis(i,p[i])=\sum dep[i]+dep[p[i]]-2*dep[ ...