-
1.对象序列化,反序列化:将对象转换成byte序列,反之叫对象的反序列化; 2.序列化流(ObjectOutputStream 字节过滤流)-- writeObject 3.反序列化流(ObjectInputStream) -- readObject 4.序列化接口(Serializable)-- 没有任何方法,只是一个标准 注意:对象必须实现序列化接口,才能序列化,否则将出现异常查看全部
-
IO流(输入流、输出流) 字节流、字符流 1 字节流 InputStream、OutputStream InputStream抽象了应用程序读取数据的方式 OutputStream抽象了应用程序写出数据的方式 EOF = End 读到-1就读到结尾 输入流基本方法: int b = in.read();读取一个字节无符号填充到int低八位。-1是EOF in.read(byte[] buf) in.read(byte[] buf,int start,int size) 输出流基本方法 out.write(int b) 写出一个byte到流,b的低8位 out.write(byte[] buf)将buf字节数组都写入到流 out.write(byte[] int start,int size) FileInputStream--->具体实现了在文件上读取数据查看全部
-
字符流 1)编码问题 2)认识文本和文本文件 java的文本(char)是16位无符号编码,是字符的Unicode编码(双字节编码) 文件是byte byte。。。的数据序列 文本文件是文本(char)序列按照某种编码方案(utf-8,utf-16be,gbk)序列化为byte的存储结果 3)字符流分为输入流(Reader)和输出流(Writer) 字符处理,一次处理一个字符 字符处理底层还是基本的字节序列 InputStreamReader 完成byte流解析为char流,按照编码解析 OutputStreamWriter 提供char流到byte流,按照编码处理查看全部
-
RandomAccessFile Java提供的对文件内容的访问 既可以读文件,也可以写文件 支持随机访问文件,可以访问文件的任意位置 Java文件模型 1 在硬盘上的文件时byte存储的,是数据的集合 2 打开文件 有两种模式“rw”(读写)“r”(只读) RandomAccessFile raf = RandomAccessFile(file,"rw") 文件指针,打开文件时指针在开头 pointer = 0; 3 写方法 raf.write(int)——》只写一个字节(后8位),同时指针指向下一个位置,准备再次写入 4 读方法 int b = raf.read()——》读一个字节 5 文件读写完成后一定要关闭(Oracle官方说明)查看全部
-
IO流(输入流 输出流) 字节流,字符流 1.字节流 1)InputStream,OutputStream InputStream 抽象了应用程序读取数据的方式 OutputStream 抽象了应用程序写出数据的方式。 2) EOF = END 读到-1就读到结尾 3) 输入流基本方法 int b = in.read();读取一个字节无符号填充到int低八位,-1是EOF in.read(byte[] buf);读取数据填充到字节数组buf in.read(byte[] buf,int start,int size);读取数据到字节数组buf,从buf的start位置开始存放size长度的数据 4)输出流基本方法 out.write(int b) 写出一个byte到流,b的低8位 out.write(byte[] buf)将buf字节数组都写入到流 out.write(byte[] buf,int start,int size);字节数组buf从start位置开始写size长度的字节到流 5)FileInputStream--->具体实现了在文件上读取数据 6)FileOutputStream 实现了向文件中写出byte数据的方法 7) DateOutputStream/DateInputStream 对"流"功能的扩展,可以更加方便的读取int,long,字符等类型数据 DateOutputStream writeInt()/writeDouble()/writeUTF() 8)BufferedInputStream,BufferedOutputStream 这两个流类为IO提供了带缓冲区的操作,一般打开文件进行写入 或读取操作时,都会加上缓冲,这种流模式提高了IO到性能 从应用程序中把输入放入文件,相当于将一缸水倒入到另一缸中: FileOutputStream--->write()方法相当于一滴一滴地把水"转移"过去 DataOutputStream-->writeXxx()方法会方便一些,相当于一瓢一瓢把水"转移"过去 BufferedOutputStream--->write方法更方便,相当于一瓢一瓢先放入桶中,在从桶中倒入另一个缸中,性能提到了查看全部
-
3、is.read() 单字节适合读取 小 文件 is.read(byte[] bytes,int star,int size) 字节数组适合读取 大 文件 byte 类型 8 位,int 类型 32 位,为了避免数据转换错误,通过 & 0xff 将高 24 位清零查看全部
-
File类的使用 java.io.File类用于表示文件(目录) File类只用于表示文件(目录)的信息(名称、大小等),不能用于文件内容的访问查看全部
-
IO流(输入流、输出流) 1、字节流、字符流 1)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的低八位 out.write(byte[] buf); out.write(byte[] buf,int start,int size); 5)FileInputStream--->具体实现了在文件上读取数据查看全部
-
1.RandomAccessFile :java提供的对文件内容的访问,可以读写文件;支持随机访问文件,可以访问文件的任意位置 2.java文件模型:在硬盘上的文件是byte byte byte存储的,数据的集合 3.RandomAccessFile raf = new RandomAccessFile(file,"rw"); 4.RandomAccessFile具有文件指针,打开文件时指针在开头 pointer = 0 5.raf.write(int)-- > 只写一个字节(后8位),同时指针指向下一个位置,准备再次写入 6.int b = raf.read() -- > 读一个字节 注意:文件读写完成以后一定要关闭(Oracle官方说明),因为存在未知风险 raf.write(i>>>24);//高八位查看全部
-
file.list() 返回当前目录下的子目录和文件的字符串数组名称 file.listFiles() 返回当前目录下的所有子目录和文件的文件数组名称 File[] files = dir.listFiles();//返回的是直接子目录(文件)的抽象 if (file!=null && files.length > 0){ for(File file:files){ if(file.isDrectory()){ listDirectory(file); }else{ System.out.println(file); } } }查看全部
-
JAVA I/O 输入输出流 编码问题 File类的使用 RandomAccessFile的使用 字节流的使用 字符流的使用 对象的序列化和反序列化 gbk编码:中文占2个字节,英文占1个字节 utf-8编码:中文站3个字节,英文占1个字节 utf-16be:中英文都占2个字节查看全部
-
transient 字段默认不进行序列化查看全部
-
字符批量读查看全部
-
字符读取也可批量读取查看全部
-
文本:java的char, 是双字节,Unicode 编码 文件:byte byte byte 文本文件:文本按照某种编码 方式的字节存储查看全部
举报
0/150
提交
取消