黑马程序猿——25,打印流,合并流,对象序列化,管道流,RandomAccessFile
------<ahref="http://www.itheima.com" target="blank">Java培训、Android培训、iOS培训、.Net培训</a>、期待与您交流!
-------
黑马程序猿——25。打印流。合并流。对象序列化,管道流,RandomAccessFile
/*
IO流的打印流:专门用于打印的流
字节打印流PrintStream
PrintStream的构造函数能够接收file对象,String型字符串路径,字节输出流
字符打印流PrintWriter
PrintWriter的构造函数能够接收file对象,字符串路径。字节输出流,字符输出流
PrintWriter有刷新方法。写的时候记得刷新。
*/
import java.io.*;
class Ioliou25
{
public static void main(String[] args)throws IOException
{
File f=new File("f:\\yyyyyyyk.txt");
BufferedReader bufr=new BufferedReader(new InputStreamReader(System.in));
// PrintWriter pw=new PrintWriter(System.out,true);//这个带true的就自己主动刷新,不用写flush方法了
//InputStreamReader是字节与字符的桥梁
//PrintWriter pw=new PrintWriter(f,true);//这样的写法编译错误,PrintWriter类没有这样的构造函数
/*
PrintWriter构造函数里面能够带true的仅仅有
PrintWriter(OutputStream out,boolean autoFlush)
PrintWriter(Writerout, boolean autoFlush)
*/
// PrintWriter pw=new PrintWriter(System.out);
PrintWriter pw=new PrintWriter(new FileWriter(f),true);//使用FileWriter嵌套f的话就能够带true
String s=null;
while((s=bufr.readLine())!=null)
{
if(s.equals("over"))//设置结束语句
break; // pw.write(s.toUpperCase()); //没有换行
pw.println(s.toUpperCase());//这个使用println方法更为常见
//pw.flush();
}
bufr.close();
pw.close(); }
public static void soc(Object obj)
{
System.out.println(obj);
}
}
——————切割线————
/*
分割文件 */
import java.io.*;
import java.util.*; class Ioliou27
{
public static void main(String[] args)throws IOException
{
//qiege();
//hebing();
hebing2(); }
publicstatic void qiege()/*分割文件*/throws IOException
{
File f=new File("f:\\8.11\\8.11练习.png");//建立文件对象
FileInputStream fis=new FileInputStream(f);//关联目的文件
FileOutputStream fos=null;
int i=0,k=0;
byte[] by=new byte[1024*10];
while((i=fis.read(by))!=-1)
{
k++;
fos=new FileOutputStream("f:\\8.11\\8.11练习"+k+".part");
//每一次循环k值都不同所以相应有不同的关联的碎片文件
fos.write(by,0,i); }
fis.close();
fos.close();
}
public static void hebing()/*合并文件*/throws IOException
{
ArrayList<FileInputStream> al=new ArrayList<FileInputStream>();
//这里採用的是ArrayList集合
for(int x=1;x<=4;x++)
{
al.add(new FileInputStream("f:\\8.11\\8.11练习"+x+".part"));
//把与文件相关联的流装进集合中
}
final Iterator<FileInputStream> it= al.iterator();
//被匿名内部类訪问的局部成员要被final修饰
Enumeration<FileInputStream> en=new Enumeration<FileInputStream>()
{
public boolean hasMoreElements()
{
return it.hasNext(); }
public FileInputStream nextElement()
{
return it.next();
} };
SequenceInputStream sis=new SequenceInputStream(en);
FileOutputStream fos=new FileOutputStream("f:\\8.11\\8.11练习合并.png");
int i=0;
byte[] by= new byte[1024];
while((i=sis.read(by))!=-1)
{
fos.write(by,0,i);
}
sis.close();
fos.close(); }
public static void hebing2()/*另外一种合并方法*/throws IOException
{
Vector<FileInputStream> v=new Vector<FileInputStream>();
for(int x=1;x<=4;x++)
{
v.add(new FileInputStream("f:\\8.11\\8.11练习"+x+".part")); }
Enumeration<FileInputStream> en=v.elements();
SequenceInputStream sis=new SequenceInputStream(en);
FileOutputStream fos=new FileOutputStream("f:\\8.11\\8.11练习合并2.png");
int i=0;
byte[] by=new byte[1024*10];
while((i=sis.read(by))!=-1)
{
fos.write(by,0,i);
}
sis.close();
fos.close(); }
public static void soc(Object obj)
{ System.out.println(obj);
}
}
——————切割线——————
/*
对象的序列化
ObjectInputStream和ObjectOutputStream的使用。
序列化就是把对象储存在硬盘上。
*/
/*
实现了Serializable接口,那么该类会用uid号标识。
uid号与成员有关。
假设类中的成员发生变化,uid就会对应的发生变化。
当然也能够自己主动指定该类的固定uid
办法是在该类中加入:
public static final long serializableUID=42L;
当中举一个样例说明uid的作用:
第一次编译Per类所在java文件而产生的.class文件,
然后再编译执行主函数所在的java文件,把对象存储在硬盘上。
此时java会给Per类自己主动生成uid,由Per类生成的对象则是相应
也会有同样的uid
接着增删改Per类的成员。第二次编译Per类所在的java文件
而产生的.class文件相应的uid会变化的!第二次编译执行主函数
所在的java文件须要读取对象的时候就会报出执行异常。由于。
已经储存在硬盘里面的对象的uid号是第一次的uid号,Per类所在的
java文件第二次产生的.class文件的uid号与对象的uid号不同,所以
就会出现异常。
为了解决问题,在Per类中加入
public static final long serializableUID=42L;
就使得不管Per类怎么修改都仅仅有相应一个uid号。
Per类的对象uid号也是这个,Per类编译产生的.class文件uid号也是这个。
对象在硬盘上的写入和读取都相应同一个uid号。就不会发生异常了。
*/
import java.io.*;
import java.util.*; class Ioliou28
{
public static void main(String[] args)throws Exception
{
// xieru();
duqu() ;
}
public static void xieru() throws Exception
{
File f=new File("f:\\北方.txt");
FileOutputStream fos=new FileOutputStream(f);
ObjectOutputStream oops=new ObjectOutputStream(fos);
oops.writeObject(new Per("呼呼呼",26,"jkl"));
//写入对象,写入的对象所属的类必须是实现了Serializable借口
oops.close();
}
public static void duqu() throws Exception
{
File f=new File("f:\\北方.txt");
FileInputStream fos=new FileInputStream(f);
ObjectInputStream oips=new ObjectInputStream(fos);
Object obj=oips.readObject();//readObject方法返回的是Object类型的对象
//readObject方法会抛出一个ClassNotFoundException,为了简便。抛出都是Exception
Per p =(Per)obj;
oips.close();
soc(p); }
public static void soc(Object obj)
{
System.out.println(obj);
} }
import java.io.*;
import java.util.*;
class Per implements Serializable
{
//public static final long serializableUID=42L; static String name="无名";//静态成员不能被序列化
private int age;
transient String country="cn";//transient修饰的成员也不能被序列化
Per(String name, int age,String country)
{
this.name=name;
this.age=age;
this.country=country ;
}
public String toString()
{
return name+":"+age+":"+country;
}
}
——————切割线——————
/*
管道流:
PipedInputStream PipedOutputStream
管道输入流和管道输出流能够连接,与多线程密切相关。
通常是一条线程负责管道输入流,一条线程负责管道输出流。
*/
class Read() implements Runnable throws IOException
{
private PipedInputStream pis=null; Read(PipedInputStream pis)
{
this.pis=pis;
}
public void run()
{
int i=0;
byte[] by=new byte[1024];
while((i=pis.read(by))!=-1)
{
//填写内容
}
}
}
class Write() implements Runnable throws IOException
{
private PipedOutputStream pos=null;
Write(PipedOutputStream pos)
{
this.pos=pos;
}
public void run( )
{
// int i=0;
// byte[] by=new byte[1024];
pos.write("huhuhu".getBytes());
}
}
import java.io.*;
class Ioliou29
{
public static void main(String[] args)throws IOException
{
PipedInputStream pis=new PipedInputStream();
PipedOutputStream pos=new PipedOutputStream();
pis.connect(pos);//管道输入流和管道输出流连接
Read r=new Read(pis);
Write w=new Write(pos);
Thread t1=new Thread(r);
Thread t2=new Thread(w);
t1.start();
t2.start();
}
public static void soc(Object obj)
{
System.out.println(obj);
}
}
——————切割线——————
/*
RandomAccessFile类是IO包的成员
随机訪问,这个类应用的非常广。
里面封装了字节写入流和字节读取流,
所以具备了读写的功能,
可是仅仅是针对文件才干够进行操作,不能对路径进行操作。
操作文件还须要模式:
经常使用的两种模式:"r"仅仅读。"rw"读写。
该类里面还封装了很大的数组。另一个指针指示数组。
通过getFilePointer方法获得指针位置。
通过seek方法指定指针位置
*/
import java.io.*;
class Ioliou30
{
publicstatic void main(String[] args) throws IOException
{
write();
read(); }
public static void write()throws IOException
{
File f=new File("f:\\学习.txt");
RandomAccessFile raf=new RandomAccessFile(f,"rw");//关联文件并确定操作模式
//假设文件不存在会自己主动创建
raf.write("一二三".getBytes());
raf.writeInt(56);//写入数字时最好用writeInt,以32位形式写入
raf.write("四五六".getBytes());
raf.writeInt(85);//写入数字时最好用writeInt,以32位形式写入 }
public static void read()throws IOException
{
File f=new File("f:\\学习.txt");
RandomAccessFile raf=new RandomAccessFile(f,"rw");//关联文件并确定操作模式
soc("raf.getFilePointer()="+raf.getFilePointer());//getFilePointer方法返回内部数组指针位置 //raf.seek(2);//调整内部数组的指针指向第2位
byte[] by=new byte[4];
raf.read(by);//依照字节数组读取
String s=new String(by);//依照字节数组转成字符串
int i= raf.readInt();//依照32位读取数据 soc(s);
soc(i); }
public static void soc(Object obj)
{
System.out.println(obj);
}
}
黑马程序猿——25,打印流,合并流,对象序列化,管道流,RandomAccessFile的更多相关文章
- 黑马程序猿——15,String,StringBuffer,基本数据类型包装对象
------<ahref="http://www.itheima.com" target="blank">Java培训.Android培训.iOS培 ...
- 黑马程序猿————Java基础日常笔记---反射与正則表達式
------Java培训.Android培训.iOS培训..Net培训.期待与您交流! ------- 黑马程序猿----Java基础日常笔记---反射与正則表達式 1.1反射 反射的理解和作用: 首 ...
- 黑马程序猿_Java 代理机制学习总结
-------<a href="http://www.itheima.com/"">android培训</a>.<a href=" ...
- Java API —— IO流(数据操作流 & 内存操作流 & 打印流 & 标准输入输出流 & 随机访问流 & 合并流 & 序列化流 & Properties & NIO)
1.操作基本数据类型的流 1) 操作基本数据类型 · DataInputStream:数据输入流允许应用程序以与机器无关方式从底层输入流中读取基本 Java 数据类型.应用程序可以使用数据输出 ...
- 黑马程序猿——JAVA基础——IO流
----------android培训.java培训.java学习型技术博客.期待与您交流!------------ 一. 一.IO流的三种分类方式 1.按流的方向分为:输入流和输出流 2.按流的数 ...
- IO流(一)__File对象和字符流FileWriter FileReader
IO流:IO流用来处理设备之间的数据传输,Java对于流的操作对象都在IO包中将外设中的数据读取到内存中:输入将内存的数写入到外设中:输出 流分为字节流和字符流字符流的由来:其实就是字节流读取文字字节 ...
- node.js 从文件流中读写数据及管道流
读取数据 // 引入 fs 模块 const fs = require('fs'); // 创建可读流 let readStream = fs.createReadStream('index.txt' ...
- 黑马程序猿 IO流 ByteArrayInputStream与ByteArrayOutputStream
---------------------- ASP.Net+Unity开发..Net培训.期待与您交流! ---------------------- package cn.itcast.IO; i ...
- 黑马程序猿——Java中的类载入器
------- android培训.java培训.期待与您交流! -------- 类载入器 Java虚拟机中能够安装多个类载入器,系统默认三个主要类载入器,每一个类负责载入特定位置的类: BootS ...
随机推荐
- KD100遥控生成仪
KD100是KEYDIY公司开发的一个强大的车用/民用遥控器生成工具,所生成的遥控器都具备不重码,质量稳定的特点. 通过采用英飞凌和NXP等公司开发的超级芯片,KD100巧妙的解决了各类型遥控器的兼容 ...
- js 面试的坑
JavaScript事件属性event.target <!DOCTYPE html> <html> <head> <meta charset="UT ...
- matlab colormap
This table lists the built-in colormaps functions. Colormap Name Color Scale parula
- 【资料】wod地城掉落
•林中强盗第三层樵夫的皮带子蓝色毡帽面包刀(必定掉) •前往米勒巴赫的旅程第一层木棒邪恶强盗披风邪恶强盗匕首第二层地精盾第三层一瓶啤酒(必定掉大啤酒杯(必定掉 •喧嚷的酒吧第一层指挥棒(传奇等级10旅 ...
- Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例 本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显示出来,该例子也会涉及到Android加载大图片时候的处理 ...
- Struts2自定义Result处理JSON
以前在采用Struts2开发的项目中,对JSON的处理一直都在Action里处理的,在Action中直接Response,最近研读了一下Struts2的源码,发现了一个更加优雅的解决办法,自己定义一个 ...
- mongodb,redis,memcached,mysql对比
1.性能都比较高,性能对我们来说应该都不是瓶颈总体来讲,TPS方面redis和memcache差不多,要大于mongodb 2.操作的便利性memcache数据结构单一redis丰富一些,数据操作方面 ...
- [Android开发常见问题-16] FragmentActivity cannot be resolve to a type
只需要将android-support-v4.jar放到自己的libs目录下即可. 如果ADT版本比较低,则放到libs之后还需要按照下图导入这个jar包.
- Backup and restore of FAST Search for SharePoint 2010
一个同事问我一个问题: 如果FAST Search for SharePoint 2010被full restore到了一个之前的时间点, 那么当FAST Search重新开始一个增量爬网的时候, 会 ...
- 从AIDL开始谈Android进程间Binder通信机制
转自: http://tech.cnnetsec.com/585.html 本文首先概述了Android的进程间通信的Binder机制,然后结合一个AIDL的例子,对Binder机制进行了解析. 概述 ...