递归、序列化和反序列化



//字节读

FileInputStream fis=new fileInputStream(file);

byte[] b=new byte[1024];

int len=0;

while((len=fis.read(b))!=-1){

.//将字节数组长转成字符串

String s=new String(b,o,len);

}

//字符读

FileReader fr=new FileReader(file);
char cbuf[]=new char[1024];
int len=0;
while((len=fr.read(cbuf))!=-1){
//字符数组转成字符串
String s=new String(cbuf, 0, len);
System.out.println(s);
}



//字符写

PrintWriter pw=new PrintWriter(file);
pw.write("新内容");
pw.close();


递归:方法里面调方法。递归策略只需少量的程序就可描述出解题过程所需要的多次重复计算,大大地减少了程序的代码量。

例:
import java.io.File;


 package com.zking.io;


import java.io.File;


public class TestDiGui {

public static void main(String[] args) {
File f=new File("C:\\Users\\Administrator\\Desktop\\a");
read(f);
}
/**

* @param f 文件 【文件夹】
*/
public static void read(File f){
if(f.isDirectory()){
//文件夹
//列出该文件夹下所有的文件
File fs[]=f.listFiles();
if(fs.length>0){
//有子目录或者子文件
for (File file : fs) {
if(file.isDirectory()){
read(file);
}else{
System.out.println(file.getAbsolutePath());
}
}
}else{
//没有子目录或者子文件
System.out.println(f.getAbsolutePath());
}
}else{
//文件
System.out.println(f.getAbsolutePath());
}
}
}


序列化:将对象存到硬盘中(乱码)

反序列化:将存档从硬盘中读出(控制台)

具体实现代码:

Person person=new Person("admin", "123");

try {

//序列化

ObjectOutputStream oos=new ObjectOutputStream(new  FileOutputStream("user.exe"));

oos.writeObject(person);

       oos.close();

 

//反序列化

ObjectInputStream ois=new ObjectInputStream(new FileInputStream("user.exe"));

Person person2=(Person) ois.readObject();

System.out.println(person2);

ois.close();

} catch (Exception e) {

e.printStackTrace();

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值