I/O流使用练习
1.实现文件加密操作。
提示:加密是指使文件出现了类似乱码,无法看懂的状态。
int b = 0;
while((b = fis.read()) != -1){
fos.write(b ^ 5);//异或运算
}
@Test
//2.文件的加密操作,解密也是如此
public void testSecret(){
FileInputStream fis = null;
FileOutputStream fos = null;
try{
fis = new FileInputStream(new File("E:\\java\\javaSenior\\Day_09\\壁纸.jpg"));
fos = new FileOutputStream(new File("E:\\java\\javaSenior\\Day_09\\加密壁纸.jpg"));
byte[] buffer = new byte[1024];
int len;
while ((len=fis.read(buffer))!=-1){//read()读到末尾时返回-1
for(int i=0;i<len;i++){
buffer[i] = (byte) (buffer[i] ^ 5);//异或操作,加密和解密一样,无需修改
}
}
}catch (IOException e){
e.printStackTrace();
}finally{
if(fis!=null){
try{
fis.close();
}catch(IOException e){
e.printStackTrace();
}
}
if(fos!=null){
try{
fos.close();
}catch(IOException e){
e.printStackTrace();
}
}
}
}
2.获取文本上每个字符出现的次数
提示:遍历文本的每一个字符;字符及出现的次数保存在Map中;将Map中数据写入文件。
import java.io.*;
import java.util.HashMap;
import java.util.Map;
import java.util.Set;
/**
* 统计一篇文章中的各个字符出现的次数,并输出到文件中
* @author wds
* @date 2021-11-27-13:09
*/
public class CountWordTest {
public static void main(String[] args) {
FileReader fr = null;
BufferedWriter bw = null;
try {
//1.创建Map集合
Map<Character, Integer> map = new HashMap<>();
//2.遍历每一个字符,每一个字符出现的次数统计到Map中
fr = new FileReader("E:\\java\\javaSenior\\Day_09\\Hello.txt");
int c = 0;
while ((c = fr.read()) != -1) {
char ch = (char) c;
//判断是否是第一次出现
if (map.get(ch) == null) {
map.put(ch, 1);
} else {
map.put(ch, map.get(ch) + 1);
}
}
//3.把map中的数据存储在文件count.txt中
//3.1创建writer
bw = new BufferedWriter(new FileWriter("E:\\java\\javaSenior\\Day_09\\count.txt"));
//3.2遍历map,在写入数据
Set<Map.Entry<Character, Integer>> entries = map.entrySet();
for (Map.Entry<Character, Integer> entry : entries) {
switch (entry.getKey()) {
case ' ':
bw.write("空格=" + entry.getValue());
break;
case '\t':
bw.write("tab键=" + entry.getValue());
break;
case '\r':
bw.write("回车=" + entry.getValue());
break;
case '\n':
bw.write("换行=" + entry.getValue());
break;
default:
bw.write(entry.getKey() + "=" + entry.getValue());
break;
}
bw.newLine();//换行操作
}
} catch (IOException e) {
e.printStackTrace();
} finally {
if (bw != null) {
try {
bw.close();
} catch (IOException e) {
e.printStackTrace();
}
}
if (fr != null) {
try {
fr.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
}
}