-
IO——对象的序列化和反序列化 一、概念 1、对象序列化,就是将Object转换成byte序列,反之叫对象的反序列化 2、序列化流(ObjectOutputStream),字节的过滤流 —— writeObject()方法 反序列化流(ObjectInputStream) —— readObject()方法,读出来是object类 记得转换 3、序列化接口(Serializable) 对象必须实现序列化接口,才能进行序列化,否则将出现异常。 这个借口,没有任何方法,只是一个【标准】查看全部
-
字符流的过滤器: BufferedReader readLine 一次读一行 BufferedWriter/PrintWriter 写一行 BufferedReader br=new BuffereReader( new InputStreamReader (new FileInputStream("e:\\javaio\\imooc.txt"))); BufferedWRiter bw=new BufferedWriter( new OutputSteamWriter( new FileOutputStream("e:\\javaio\\immoc3.txt"))); PrintWriter pw=new PrintWriter("e:\\javaio\\imooc4.txt"); String line; while ((line=br.readLine())!=null){ syso -> line; bw.write(line); bw.newLine(); //换行操作 bw.flush(); //或 pw.print(line); // pw.println(line); pw.flush(); } br.close(); bw.close(); pw.close()查看全部
-
5.字符流:字符流分为输出流(Reader)和输出流(Writer)。操作的是文本文件。 字符处理,一次处理一个字符 字符处理底层还是基本的字节序列 InputStreamReader:完成byte流解析为char流,按照编码解析 FileInputStream in = new FileInputStream("e:\\javaio\\imoocutf8.txt"); //获取字符输入流 InputStreamReader isr = new InputStreamReader(in,"utf-8");//默认项目的编码,操作的时候,要写文件本身的编码格式 OutputStreamWriter:提供char流到byte流,按照编码处理 FileOutputStream out = new FileOutputStream("e:\\javaio\\imoocutf81.txt"); //获取字符输出流 OutputStreamWriter osw = new OutputStreamWriter(out,"utf-8"); FileReader/FileWriter:可以直接写文件名的路径。与InputStreamReader相比坏处:无法指定读取和写出的编码,容易出现乱码。 FileReader fr = new FileReader("e:\\javaio\\imooc.txt"); //输入流 FileWriter fw = new FileWriter("e:\\javaio\\imooc2.txt");//输出流查看全部
-
2.字符流 (操作的是文本 文本文件) 注意默认的编码方式 1)编码问题 2)认识文本和文本文件 java的文本(char)是16位无符号整数,是字符的unicode编码(双字节编码) 文件是byte byte byte 的数据序列 文本文件是文本(char)序列按照某种编码方案(utf-8,utf-16be,gbk)序列化byte的存储 3)字符流(Reader Writer) 字符的处理,一次处理一个字符 字符的底层依然是基本的字节序列 4)InputStreamreader 完成byte流解析成char流 按照编码解析 OutputStreamWrite 提供char流到byte流 按照编码处理 FileInputStream in=new FileInputStream("e:\\javaio\\imooc.txt"); InputSreamStreamReader isr=new InputStreamReader(in);//默认项目编码 gbk 可改成 utf-8 int c; while((c=isr.read())!=-1){ syso -> char(c) } //一次读一个字符数组 char[] buffer=new char[8*1024]; int c; while ((c=isr.read(buffer,0,buffer.length))!=-1){ 批量读取放入buffer这个字符数组 从第0个位置开始防止,最多放置buffer.length个 String s=new String(buffer,0,c); syso -> s; }查看全部
-
& 0xff查看全部
-
哎呀 听不懂了查看全部
-
BufferedInputSteram和BufferedOutputStream: 提供了带缓冲区的操作,一般打开文件进行写入或读取时,都会加上缓冲,提高了IO的性能。 FileOutputStream--->write()一滴一滴写 DataOutputStream--->writeXXX()相当与一瓢一瓢的写 BufferedOutputStream--->write()相当于一瓢一瓢先放入桶中,然后一整桶写 使用BufferedInputSteram和BufferedOutputStream时,要到用flush()刷新缓冲区。查看全部
-
readInt readLong 方法都是对FileInputStream方法的包装 DataOutputStream/DataInputStream 对“流”功能的扩展,可以更加方便的读取 int,long, 字符等类型数据 DataOutputStream:使用FileOutputStream构造出来,通过包装FileOutput,可以调用FileOutput类的write方法来构造新的更方便的写方法: new DataOutputStream(new FileOutptStream(file)) wrieteUTF()采用utf-8编码写出字符串 用utf-16be写出字符串,或字符串数组 写完之后一定要关闭流 数据输入输出流: DataInputStream、DataOutputStream 是对“流”功能的扩展,方便读写 DataOutputStream dos = new DataOutputStream(new FileOutputStream(file)); dos.writeInt(10); dos.writeLong(10l);字母l dos.writeDouble(10.5); //采用utf-8编码写出 dos.writeUTF("中国"); //采用utf-16be编码写出 dos.writeChars("中国");查看全部
-
/** * 文件拷贝,字节批量读取 * @param srcFile * @param destFile * @throws IOException * * JAVA的throw和throws区别: * http://zhidao.baidu.com/link?url=cOoyefusSFJRvXFuNK3vAVS_mGcE3jgWSy8CiwZk5y-N8Fa-m_cwRrNVEneXKkwMOTYHz8MIIS13gAz91Y4vZ_ */ public static void copyFile(File srcFile,File destFile)throws IOException{ if(!srcFile.exists()){ throw new IllegalArgumentException("文件:"+srcFile+"不存在"); } if(!srcFile.isFile()){ throw new IllegalArgumentException(srcFile+"不是文件"); } FileInputStream in = new FileInputStream(srcFile); FileOutputStream out = new FileOutputStream(destFile); byte[] buf = new byte[8*1024]; int b ; while((b = in.read(buf,0,buf.length))!=-1){ //将buf数组里的內容读入到该输出流中(out) out.write(buf,0,b); out.flush();//最好加上 } in.close(); out.close(); }查看全部
-
1、byte 类型 8 位,int 类型 32 位,为了避免数据转换错误,通过 & 0xff 将高 24 位清零 2、long time = System.currentTimeMillis() 当前时间与协调世界时 1970 年 1 月 1 日午夜之间的时间差(以毫秒为单位测量) 3、is.read() 单字节适合读取 小 文件 is.read(byte[] bytes,int star,int size) 字节数组适合读取 大 文件查看全部
-
输出流基本方法 out.write(int b) out.write(byte[] buf) out.write(byte[] buf, int start, int size)查看全部
-
输入流基本方式 int b = in.read(); in.read(byte[] buf) in.read(byte[] buf, int srart, int size)查看全部
-
I/O 读写打开文件模型查看全部
-
public String[] list()返回一个字符串数组,这些字符串指定此抽象路径名表示的目录中的文件和目录。 exists()方法用于判断文件或目录是否存在 file.list() 返回的是 字符串数组 直接子的名称,不包含子目录下的内容 file.listFiles() 返回当前目录下的所有子目录和文件的文件数组名称 ======================================== 如果要遍历子目录下的内容就需要构造成File对象做递归操作 //throws IOException 回避了IO的抛出异常 File[] files = dir.listFiles();//返回的是直接子目录(文件)的抽象 if (file!=null && files.length > 0){ for(File file:files){ if(file.isDrectory()){ listDirectory(file); }else{ System.out.println(file); } } }查看全部
-
见图, file.mkdir()创建目录(一级目录),如果多级目录mkdirs(); getAbsolutePath() 如果file路径,getName返回子路径 如果file为文件,getName返回文件名称 getParent()父路径查看全部
举报
0/150
提交
取消