-
File.list()方法用于列出当前目录下的子目录和文件,获取该目录下的所有文件
File.listFiles()返回的是直接子目录(文件)的抽象,获取该目录下所有文件和目录的绝对路径
通过list()方法获取的结果:
通过listFiles()方法获取的结果:
图转自博客:bingguang1993
查看全部 -
File file=new File("E:\\javaio\\imooc"),“\\”或“//”是中间的分隔符,也可以用File.separator。
file.exists()跟其字面意思一样,用于判断文件知否存在
file.mkdir()可以直接创建文件夹(E:\\javaio\\imooc),file.mkdirs()可以创建多级目录,file.createNewFile()可以直接创建文件("E:\\javaio\\日记1.txt"),配合exists做个if else判断比较好
file.delete()删除
file.isDirectory()判断是否是一个目录,是返回true,不是目录或者目录不存在返回false,file.isFile()判读是否是一个文件
File file2=new File("E:\\javaio","日记1.txt")是另一个构造函数,第一个参数代表目录,第二个代表文件
以下为几种File类中简单的方法
查看全部 -
1.Integer.toHexString(byte)把字节(转换成了int)以16进制的方式显示 ,byte转换成int相当于int后八位为byte原来的,后八位前24位加上24个0,
2.Integer.toHexString(byte%0xff) 把前头的0取掉,只留下后八位
3.转换成字节序列用的是项目默认的编码gbk,中文占用2个字节,英文占用1个字节
4.byte[] byte=s.getBytes()是用默认编码,byte[] byte=s.getBytes(参数)是用参数指定的编码(参数为:“某种编码”)
5.utf-8编码中文占用3个字节,英文占用1个字节
6.java是双字节编码,utf-16be编码,字符串一个字符占两个字节, 中文占用2个字节,英文占用2个字节。
7.当你的字节序列式某种编码时,这个时候想把字节序列变成字符串,也需要用这种编码方式,否则会出现乱码。String str1=new String(byte):用项目默认的编码,String str2=new String(byte,参数):用参数指定的编码。比如byte[] byte=String.getBytes("utf-8"),那么将此字节序列变成字符串就要用String str=new Stirng(byte,"utf-8")。用gbk编码的字节序列直接用第一种不指定编码参数的方法即可,因为默认的就是用gbk编码所以不用gbk编码
8.文本文件就是字节序列,可以是任意编码的字节序列。如果我们在中文机器上直接创建文本文件,那么该文本文件只认识ansi编码,中文系统下,ansi编码代表gbk编码
9.中文机器上你直接创建一个文本文件,那么它只能认识ansi编码(gbk),但是文本文件本身可以放各种编码,直接粘贴到中文机器上的无论编码是哪种它都认识,只不过在中文机器上直接创建时会有这个特殊性。
10.某个项目的文本文件只认识项目指定的编码,换一种别的编码他就不认识了。比如你把用utf-8编码的A项目下的文本文件直接拷贝到使用默认编码gbk的B项目下,拷贝的文件里就会出现乱码,但如果只是把A项目文本文件中的内容拷贝到B项目下的文本文件中,他会自动进行转换
查看全部 -
一个类实现了序列化接口,那么其子类都可以进行序列化
查看全部 -
package com.imooc.io;
import java.io.FileInputStream;
import java.io.ObjectInputStream;
public class ObjectSeriaDemo1 {
public static void main(String[] args) throws Exception{
String file = "demo/obj.dat";
//1.对象的序列化
/*ObjectOutputStream oos = new ObjectOutputStream(
new FileOutputStream(file));
Student stu = new Student("10001", "张三", 20);
oos.writeObject(stu);
oos.flush();
oos.close();*/
ObjectInputStream ois = new ObjectInputStream(
new FileInputStream(file));
Student stu = (Student)ois.readObject();
System.out.println(stu);
ois.close();
}
}
查看全部 -
package com.imooc.io;
import java.io.Serializable;
public class Student implements Serializable{
private String stuno;
private String stuname;
//该元素不会进行jvm默认的序列化,也可以自己完成这个元素的序列化
private transient int stuage;
public Student(String stuno, String stuname, int stuage) {
super();
this.stuno = stuno;
this.stuname = stuname;
this.stuage = stuage;
}
public String getStuno() {
return stuno;
}
public void setStuno(String stuno) {
this.stuno = stuno;
}
public String getStuname() {
return stuname;
}
public void setStuname(String stuname) {
this.stuname = stuname;
}
public int getStuage() {
return stuage;
}
public void setStuage(int stuage) {
this.stuage = stuage;
}
@Override
public String toString() {
return "Student [stuno=" + stuno + ", stuname=" + stuname + ", stuage="
+ stuage + "]";
}
private void writeObject(java.io.ObjectOutputStream s)
throws java.io.IOException{
s.defaultWriteObject();//把jvm能默认序列化的元素进行序列化操作
s.writeInt(stuage);//自己完成stuage的序列化
}
private void readObject(java.io.ObjectInputStream s)
throws java.io.IOException, ClassNotFoundException{
s.defaultReadObject();//把jvm能默认反序列化的元素进行反序列化操作
this.stuage = s.readInt();//自己完成stuage的反序列化操作
}
}
查看全部 -
java.io.File类用于表示文件(目录)
File类只用于表示文件(目录)的信息(名称、大小等),不能用于文件内容的访问
RandomAccessFile java提供的对文件内容的访问,既可以读文件,也可以写文件。
RandomAccessFile支持随机访问文件,可以访问文件的任意位置
(1)java文件模型
在硬盘上的文件是byte byte byte存储的,是数据的集合
(2)打开文件
有两种模式"rw"(读写) "r"(只读)
RandomAccessFile raf = new RandomeAccessFile(file,"rw")
文件指针,打开文件时指针在开头 pointer = 0;
(3) 写方法
raf.write(int)--->只写一个字节(后8位),同时指针指向下一个位置,准备再次写入
(4)读方法
int b = raf.read()--->读一个字节
(5)文件读写完成以后一定要关闭(Oracle官方说明)
序列化与基本类型序列化
1)将类型int 转换成4byte或将其他数据类型转换成byte的过程叫序列化
数据---->n byte
2)反序列化
将n个byte 转换成一个数据的过程
nbyte ---> 数据
3)RandomAccessFile提供基本类型的读写方法,可以将基本类型数据
序列化到文件或者将文件内容反序列化为数据
IO流(输入流、输出流)
字节流、字符流
1.字节流
1)InputStream、OutputStream
InputStream抽象了应用程序读取数据的方式
OutputStream抽象了应用程序写出数据的方式
2)EOF = End 读到-1就读到结尾
3)输入流基本方法
int b = in.read();读取一个字节无符号填充到int低八位.-1是 EOF
in.read(byte[] buf)
in.read(byte[] buf,int start,int size)
4)输出流基本方法
out.write(int b) 写出一个byte到流,b的低8位
out.write(byte[] buf)将buf字节数组都写入到流
out.write(byte[] buf,int start,int size)
5)FileInputStream--->具体实现了在文件上读取数据
6)FileOutputStream 实现了向文件中写出byte数据的方法
7)DataOutputStream/DataInputStream
对"流"功能的扩展,可以更加方面的读取int,long,字符等类型数据
DataOutputStream
writeInt()/writeDouble()/writeUTF()
8)BufferedInputStream&BufferedOutputStream
这两个流类位IO提供了带缓冲区的操作,一般打开文件进行写入
或读取操作时,都会加上缓冲,这种流模式提高了IO的性能
从应用程序中把输入放入文件,相当于将一缸水倒入到另一个缸中:
FileOutputStream--->write()方法相当于一滴一滴地把水“转移”过去
DataOutputStream-->writeXxx()方法会方便一些,相当于一瓢一瓢把水“转移”过去
BufferedOutputStream--->write方法更方便,相当于一飘一瓢先放入桶中,再从桶中倒入到另一个缸中,性能提高了
2.字符流
1) 编码问题
2)认识文本和文本文件
java的文本(char)是16位无符号整数,是字符的unicode编码(双字节编码)
文件是byte byte byte ...的数据序列
文本文件是文本(char)序列按照某种编码方案(utf-8,utf-16be,gbk)序列化为byte的存储结果
3)字符流(Reader Writer)---->操作的是文本文本文件
字符的处理,一次处理一个字符
字符的底层任然是基本的字节序列
字符流的基本实现
InputStreamReader 完成byte流解析为char流,按照编码解析
OutputStreamWriter 提供char流到byte流,按照编码处理
FileReader/FileWriter
字符流的过滤器
BufferedReader ---->readLine 一次读一行
BufferedWriter/PrintWriter ---->写一行
3.对象的序列化,反序列化
1)对象序列化,就是将Object转换成byte序列,反之叫对象的反序列化
2)序列化流(ObjectOutputStream),是过滤流----writeObject
反序列化流(ObjectInputStream)---readObject
3)序列化接口(Serializable)
对象必须实现序列化接口 ,才能进行序列化,否则将出现异常
这个接口,没有任何方法,只是一个标准
4) transient关键字
private void writeObject(java.io.ObjectOutputStream s)
throws java.io.IOException
private void readObject(java.io.ObjectInputStream s)
throws java.io.IOException, ClassNotFoundException
分析ArrayList源码中序列化和反序列化的问题
5)序列化中 子类和父类构造函数的调用问题
查看全部 -
没看懂的可以来看一下
查看全部 -
讲了一大堆
查看全部 -
java IO 1查看全部
-
啦啦啦查看全部
-
递归遍历目录
查看全部 -
文件输入流FileInputStream
查看全部 -
文件输出流FileOutputStream
查看全部 -
本教程几点要点:
RandomAccessFile类的使用,可以使用其中的指针自定义读取文件中的指定位置,实现分段读取,分段存储;
java文件的保存方式是字节的形式保存的,byte,因此保存的文件有编码的问题;
工程中读取或者保存在电脑中的文件会不会有乱码,与文件保存时的编码,以及工程编码属性这两个因素有关,需要注意这点;
类的序列化:可重写writeObject、readObject两个方法来自定义类的序列化方法,将某些trasient的属性自定自定序列化。
查看全部
举报