Java基础面试题——IO流

  • 增强了读写8种基本数据类型和字符串的功能

  • 增强了读写对象的功能

readObject() 从流中读取一个对象

writeObject(Object obj) 向流中写入一个对象

使用流传输对象的过程称为序列化、反序列化

序列化

// 使用objectoutputStream实现序列化

psvm(String[] args){

// 1. 创建对象流

FileOutputStream fos = new FileOutputStream(“d:\st.bin”);

ObjectOutputSream oos = new objectOutputSream(fos);

// 2. 序列化(写入操作)

Student zhangsan = new Student(“zs”, 20);

oos.WriteObject(zhangsan);

// 3. 关闭

oos.close();

sout(“序列化完毕”);

}

反序列化

// 使用ObjectInputSteam实现反序列化(读取重构对象)

psvm(String[] args){

// 1. 创建对象流

FileInputStream fis = new FileInputStream(“d:\stu.bin”);

ObjectInputStream ois = new ObjectInputStream(fis);

// 2. 读取文件(反序列化)

Student s = (Student)ois.readObject();

// 3. 关闭

ois.close();

sout(“执行完毕”);

sout(s.toString());

}

序列化注意事项

白嫖资料

  • 某个类要想序列化必须实现Serializable接口

  • 序列化类中对象属性要求实现Serializable接口

  • 序列化版本号ID,保证序列化的类和反序列化的类是同一个类

  • 使用transient修饰属性,这个属性就不能序列化

  • 静态属性不能序列化

  • 序列化多个对象,可以借助集合来实现

字符流

// 传统字节流读取

psvm(String[] args){

// 1. 创建FileInputStream对象

FileInputSteam fis = new FileInputStream(“路径”);

// 2. 读取

int data = 0;

while((data = fis.read()) != -1){

sout((char)data);

}

// 3. 关闭

fis.close();

}

字符缓冲流

白嫖资料

BufferedReader / BufferedWriter

高效读写、支持输入换行符、可一次写一行读一行

psvm(String[] args) throws Exception{

// 创建缓冲流

FileReader fr = new FileReader(“…”);

BufferedReader br = new BufferedReader(fr);

// 读取

// 1. 第一种方式

char[] buf = new char[1024];

int count = 0;

while((count = br.read(buf)) != -1){

sout(new String(buf, 0, count));

}

// 2. 第二种方式 一行一行读取

String line = null;

while((line = br.readLine()) != null){

sout(line);

}

// 关闭

br.close();

}

psvm(String[] args){

// 1. 创建BufferedWriter对象

FileWriter fw = new FileWriter(“…”);

BufferedWriter bw = new BufferedWriter(fw);

// 2. 写入

for(int i = 0; i < 10; i ++){

bw.write(“写入的内容”);

vw.newLine(); // 写入一个换行符

bw.flush();

}

// 3. 关闭

bw.close(); // 此时会自动关闭fw

}

转换流

桥转换流 InputStreamReader / OutputStreamWriter

可将字节流转换为字符流

可设置字符的编码方式

psvm(String[] args) throws Exception{

// 1 创建InputStreamReader对象

FileInputStream fis = new FisInputStream(“…”);

InputStreamReader isr = new InputStreamReader(fis, “utf-8”);

// 2 读取文件

int data = 0;

while((data = isr.read()) != -1){

sout((char)data);

}

// 3 关闭

isr.close();

}

psvm(String[] args) throws Exception{

// 1 创建OutputStreamReader对象

FileOutputStream fos = new FisOutputStream(“…”);

OutputStreamWRITER osw = new OutputStreamReader(fos, “utf-8”);

// 2 写入

for(int i = 0; i < 10; i ++){

osw.write(“写入内容”);

osw.flush();

}

// 3 关闭

osw.close();

}

File类

/*

File类的使用

  1. 分隔符

  2. 文件操作

  3. 文件夹操作

*/

public class Demo{

psvm(String[] args){

separator();

}

// 1. 分隔符

public static void separator(){

sout(“路径分隔符” + File.pathSeparator);

sout(“名称分隔符” + File.separator);

}

// 2. 文件操作

public static void fileOpen(){

// 1. 创建文件

if(!file.exists()){ // 是否存在

File file = new File(“…”);

boolean b = file.creatNewFile();

}

// 2. 删除文件

// 2.1 直接删除

file.delete(); // 成功true

// 2.2 使用jvm退出时删除

file.deleteOnExit();

// 3. 获取文件信息

sout(“获取绝对路径” + file.getAbsolutePaht());

sout(“获取路径” + file.getPath());

sout(“获取文件名称” + file.getName());

sout(“获取夫目录” + file.getParent());

sout(“获取文件长度” + file.length());

sout(“文件创建时间” + new Date(file.lashModified()).toLocalString());

// 4. 判断

sout(“是否可写” + file.canWrite());

sout(“是否是文件” + file.isFile());

sout(“是否隐藏” + file.isHidden());

}

// 文件夹操作

public static void directoryOpe() throws Exception{

// 1. 创建文件夹

File dir = new File(“…”);

总目录展示

该笔记共八个节点(由浅入深),分为三大模块。

高性能。 秒杀涉及大量的并发读和并发写,因此支持高并发访问这点非常关键。该笔记将从设计数据的动静分离方案、热点的发现与隔离、请求的削峰与分层过滤、服务端的极致优化这4个方面重点介绍。

一致性。 秒杀中商品减库存的实现方式同样关键。可想而知,有限数量的商品在同一时刻被很多倍的请求同时来减库存,减库存又分为“拍下减库存”“付款减库存”以及预扣等几种,在大并发更新的过程中都要保证数据的准确性,其难度可想而知。因此,将用一个节点来专门讲解如何设计秒杀减库存方案。

高可用。 虽然介绍了很多极致的优化思路,但现实中总难免出现一些我们考虑不到的情况,所以要保证系统的高可用和正确性,还要设计一个PlanB来兜底,以便在最坏情况发生时仍然能够从容应对。笔记的最后,将带你思考可以从哪些环节来设计兜底方案。


篇幅有限,无法一个模块一个模块详细的展示(这些要点都收集在了这份《高并发秒杀顶级教程》里),麻烦各位转发一下(可以帮助更多的人看到哟!)

由于内容太多,这里只截取部分的内容。

品在同一时刻被很多倍的请求同时来减库存,减库存又分为“拍下减库存”“付款减库存”以及预扣等几种,在大并发更新的过程中都要保证数据的准确性,其难度可想而知。因此,将用一个节点来专门讲解如何设计秒杀减库存方案。

高可用。 虽然介绍了很多极致的优化思路,但现实中总难免出现一些我们考虑不到的情况,所以要保证系统的高可用和正确性,还要设计一个PlanB来兜底,以便在最坏情况发生时仍然能够从容应对。笔记的最后,将带你思考可以从哪些环节来设计兜底方案。


篇幅有限,无法一个模块一个模块详细的展示(这些要点都收集在了这份《高并发秒杀顶级教程》里),麻烦各位转发一下(可以帮助更多的人看到哟!)

[外链图片转存中…(img-LtoCrCCw-1714353462595)]

[外链图片转存中…(img-FwNeAjyc-1714353462595)]

由于内容太多,这里只截取部分的内容。

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值