- 
            
            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的属性自定自定序列化。 查看全部
举报
 
             
         
                 
                 
                 
                 
                