Java教程

javaEE(Stream流、日志、IO流、File)

本文主要是介绍javaEE(Stream流、日志、IO流、File),对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

Stream流

简化集合和数组操作的API

List<String> list =new ArrayList<>();
Collection.addAll(list,"张1","张2","王");
 List<String> list2 -new ArrayList<>();
 for(String name:list){
	if(name.startsWith("张“)){
        list.add(name);
	}
}

list.Stream().filter(s->s.startsWith("张").filter(s->slength()==2)).forEach(s->System.out.print(s));

技术思想:

  • 先得到一个集合或者数组的Stream流
  • 把元素放到传送带上
  • 然后就使用Stream流简化API来操作元素

Stream的获取

  • 集合获得Stream流的方式
    • 可以用Collection接口中的默认方法Stream()

default Stream stream() 获得当前集合对象的Stream

  • 数组获得Stream流的方式
  • public static Stream stream (T[] array) 获取当前数组的Stream流
  • public static Stream of(T...values) 获得当前的数组/可变数据的Stream流

日志技术

  • 将系统执行的信息选择性的输出到指定的位置
  • 多线程
  • 日志规范
  • 日志框架(JCL slf4j
    • log4j 性能不好
    • JUI
    • Logback加强

logback日志框架

  • logback-core:为其他的模块提供了基础,必须有
  • logback-classic 他是log4j的一个改良版本,同时它实现了slf4j的api
  • logback-access模块和tomcat和jetty等servlet容器集成,已提供http访问日志功能
<?xml version="1.0" encoding="UTF-8"?>
<configuration debug="false" scan="true" scanPeriod="1 seconds">
 
    <contextName>logback</contextName>
 
    <property name="log.path" value="F:\\logback.log" />
 
    <appender name="console" class="ch.qos.logback.core.ConsoleAppender">
        <!-- <filter class="com.example.logback.filter.MyFilter" /> -->
        <filter class="ch.qos.logback.classic.filter.ThresholdFilter">
              <level>ERROR</level>
        </filter>
        <encoder>
            <pattern>%d{HH:mm:ss.SSS} %contextName [%thread] %-5level %logger{36} - %msg%n
            </pattern>
        </encoder>
    </appender>
 
    <appender name="file"
        class="ch.qos.logback.core.rolling.RollingFileAppender">
        <file>${log.path}</file>
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <fileNamePattern>${log.path}.%d{yyyy-MM-dd}.zip</fileNamePattern>
        </rollingPolicy>
 
        <encoder>
            <pattern>%date %level [%thread] %logger{36} [%file : %line] %msg%n
            </pattern>
        </encoder>
    </appender>
 
    <root level="debug">
        <appender-ref ref="console" />
        <appender-ref ref="file" />
    </root>
 
    <logger name="com.example.logback" level="warn" />
 
</configuration>

创建logback的日志对象

public static Looger LOGGER=LoggerFactory.getLogger("Test.class");
LOGGER.debug("main方法开始");
LOGGER.info("我记录的日志第二行");
LOGGER.trace("a="+a);
LOGGER.error("有错误");

配置

输出到控制台:

..

日志级别

trace<debug<info<warn<error

File、方法递归、IO流

  • File类可以定位文件:进行删除、获取文件本身的信息

    • 但是不能读写文件内容
  • IO流可以对硬件中的文件读写

    字节流--音乐视频文件

    字符流---文本文件

File类

java.io.File 代表操作系统的文件对象(文件、文件夹)

  • 定位文件
  • 获取文件本身的信息
  • 删除文件
  • 创建文件

常用方法:

  • public File(String pathname) 根据路径创建文件对象
  • public File (String parent, String Child) 从父路径名字字符和子路径名字字符创建文件对象
  • public File (File parent , String Child) 根据父路径对应文件对象和子路径名字字符串创建文件对象
main(){
    //创建File对象
    //路径写法:D:\\hjz\\a.jpg
    //		   D:/hjz/a.jpg
    //File.separator 分隔符
    //相对路径 相对到工程下 "sprngboot/src/data.txt"
    File f = new File("D:\\hjz\\a.jpg");
    Long a =f.length();//文件的字节大小
    f.exists()//判断文件夹是否存在
}

方法:

  • public boolean isDirectory () 测试 抽象路径名表示的File是否为文件夹
  • public boolean isFile()测试 抽象路径名表示的File是否为文件
  • public boolean exists()测试 抽象路径名表示的File是否存在
  • public String getAbsolutePath()返回的抽象路径名的绝对路径名字符串绝对路径
  • public String getPath()将此抽象路径名转化为路径名字符串自己定义的路径
  • public String getName()返回由此抽象名表的文件或文件夹的名称
  • public Long lastModified()返回文件最后修改的时间的毫秒
File f = new File("D:\hjz\a.jpg");

方法:

  • 创建:
    • public boolean createNameFile() 创建一个新的空白文件夹
    • public boolean mkdir()创建一个一级文件夹
    • public boolean mkdirs()创建一个多级文件夹
  • 删除:
    • public boolean delete() 删除由此路径表示的文件、空文件夹

删除非空文件夹要写算法

遍历:

  • public String[] list() 获取当前目录下所有的一级文件夹名称“到一个字符串数组中去返回
  • public File[] listFiles()常用 获取当前目录下所有的“一级文件对象”到一个文件对象数组中去返回重点
    • 不存在返回null
    • 调用者是文件返回null
    • 调用者是一个空文件夹返回一个长度为0的数组
    • 调用者是一个有内容的文件夹时,将里面的所有文件和文件夹的路径放在File数组中返回
    • 包含隐藏内容
File f =new File("D://")
File[] names=f.listFiles();
for(File url:names){
    syso(url.getAbsolutePath);
}

方法递归

1.递归公式

2.递归的终结点

3.递归的方向

1-n的阶乘

public static int f(int n){
    if(n==1){
        return 1;
    }else{
        return f(n-1)*n;
    }
}

1-n的和

public static int f(int n){
    if(n==1){
        return 1;
    }else{
        return f(n-1)+n;
    }
}

猴子吃桃子

/**
		f(x)-f(x)/2-1=f(x+1)
	等价变化:
		f(x)=2f(x+1)+2
	终点 
	f(10)=1
*/
public static int f(int n){
    if(n==10){
        return 1;
    }else{
        return 2*f(n+1)+2;
    }
    
}

文件搜索

1.先定位一级文件对象

2.遍历一遍一级文件对象,判断是否文件

3.如果是文件,判断是否是自己想要的

4.如果是文件夹,需要继续递归进去重复上面的过程

public static void searchFile(File dir,String name){
    if(dir!=null&&dir.isDirectory){
        //可以找了
        //获得一级文件对象
        File[] files=dir.ListFiles();
        //判断一级文件夹的对象
        if(files!=null&&files.length>0){
            for(File f:files){
                //判断当前遍历的一级文件对象是文件还是目录
                if(file.isFile()){
                    //是不是要找的文件
                    if(file.getName().contains(name)){
                        System.out.print("找到了文件是"+file.getAbsolutePath());
                            //启动它
                            Runtime r =Runtime.getRuntime();
                        r.exe(file.getAbsolutePath());
                    }else{
                        //是文件夹继续递归调用
                        searchFile(file,fileName);
                    }
                }
            }
        }
    }else{
        System.out.print("当前搜索的不是文件夹");
    }
}

啤酒问题

盖子换酒,瓶子换酒(套娃)

//买的一共酒
public static int totalNumber;
//记录瓶子的数量
public static int lastBottleNumber;
//记录剩余的盖子数目
public static int lastCoverNumber;
public static void buy(int money){
    int buyNumber = money/2;
    totalNumber+=buyNumber;
    //换成钱
    int coverNumber = lastCoverNumber+ buyNumber;
    int bottleNumber=lastBottleNumber+buyNumber;
    //统计一共多少钱
    int allNumber=0;
    if(coverNumber>=4){
        allNumber+=coverNumber/4*2;  
    }
    lastCoverNumber=coverNumber%4;
    if(lastBottleNumber>=2){
        allNumber+=(bottleNumber/2)*2
    }
    lastBottleNumber = bottleNumber%2;
    if(allNumber>=2){
        buy(allNumber);
    }
}

IO流

字符集

  • 计算机底层不能存储字符,只能存储0 1
  • 二进制转化成十进制

ASCII字符集

  • 美国信息交换标准代码:128个字符信息一个字节存储1个字符、一个字节是8位256

GBK字符集

  • 包含了几万个汉字繁体字和日韩文字、兼容ASCII字符编码表一个中文用两个字节

Unicode码表

  • 统一码是计算机科学领域栗的一项业界字符编码UTF-8(中文是以3个字节)\UTF-16

编码前的字符集和编码好的字符集要相同,不然会应为不同的字符位数错误

String编码

  • byte[] getBytes()使用平台的默认字符集将String编码为一系列字节,将结果存储到新的字节数组中
  • byte[] getBytes(String charsetName)使用指定的字符集将该String编码为一系列字节,将结果存储到新的字节数组中

String解码

  • String(byte[] bytes)通过平台的默认字符集解码在指定的字节数组构造新的String
  • String(byte[] bytes,String charsetName)通过指定的字符集解码指定的字节数组来构造新的String
String s ="abc我爱你中国";
byte[] bytes = s.getBytes();//默认编码
byte[] bytes = s.getBytes("GBK");
String ss=new String(bytes);//默认编码
String ss=new String(bytes,"GBK");

IO流:输入输出流读写数据

  • 字节流音乐,视频
  • 字符流文本内容

读入到内存输入流

写入到磁盘输出流

字节流:

  • InputStream
    • FileInputStream
      • public int read() 每次读一个,没有返回-1
      • public int read(byte[] buffer)每次读一个字节数组,没有返回-1
  • OutputStream
    • FileOutPutStream
      • public int write()
      • public int write(byte[] buffers)
      • public int write(byte[] buffers,int pos,int len) 写一部分

字符流:

  • Reader
    • FileReader
  • Writer
    • FileWriter

字节流

FileInputStream

  • 上面的都是抽象类
    • 实现类*水流模型
//1.创建一个输入流管道
//InputStream is =new FileInputStream(new File("D://..."));
//简化
InputStream is =new FileInputStream("D://...");
int b =is.read();//读取一个字节,读完返回-1
Byte[] buffer = new byte[1024];//1kb
InputStream is =new FileInputStream("D://...");
int len =is.read(buffer);
String rs= new String(butter);

常用方法:

Byte[] buffer = new byte[1024];//1kb
InputStream is =new FileInputStream("D://...");
int len=0;
while((len=is.read(butter)!=-1)){
    System.out.print(new String(butter,0,len));
}

中文乱码无法解决

//自己暴力实现
Byte[] buffer = new byte[(int)file.length()];//1kb
File file =new File("D://...");
InputStream is =new FileInputStream(file);
int len=0;
while((len=is.read(butter)!=-1)){
    System.out.print(new String(butter,0,len));
}
Byte[] buffer = is.readAllBytes();//JDK9出现
File file =new File("D://...");
InputStream is =new FileInputStream(file);
int len=0;
while((len=is.read(butter)!=-1)){
    System.out.print(new String(butter,0,len));
}

FileOutPutStream

//写会自动生成
OutputStream os =new FileOutPutStream("D://a.txt");
//OutputStream os =new FileOutPutStream("D://a.txt",true);  追加数据
os.write('a');
os.writ(98);
//写数据必须刷新数据
os.flush();
os.close();//关闭资源
byte[] buffer ={'a',97,98,90};
os.write(buffer);
byte[] buffer ="我是中国人".getBytes("GBK");
os.writer(buffer);
//注意是没有换行的
os.write("\r\n".getBytes());//换行

文件拷贝

学会字节流完成文件的复制--支持一切

try{
   //创建一个字节输入流
   InputStream is =new FileInputStream("D://img.jpg");
    //创建一个字节输出流和目标文件接通
    OutputStream os =new FileOutPutStream("D://a.txt");
   //定义一个字节数组
    byte[] buffer = new byte[1024];
    int len ;记录读取数据的字节数
        while(len=is.read(buffer)!=-1){
            os.write(buffer,0,len);
        }
    //关闭流
    os.close();
    is.close();
}catch (Exception ex){
    e.printStackTrace();
}

资源释放的方式

   InputStream is=null;
   OutputStream os=null;
   
try{
   //创建一个字节输入流
 is =new FileInputStream("D://img.jpg");
    //创建一个字节输出流和目标文件接通
  os =new FileOutPutStream("D://a.txt");
   //定义一个字节数组
    byte[] buffer = new byte[1024];
    int len ;记录读取数据的字节数
        while(len=is.read(buffer)!=-1){
            os.write(buffer,0,len);
        }

}catch (Exception ex){
    e.printStackTrace();
}finally{
        //关闭流
    //下面都要try ---catch---try{..}catch{...}
    //非空校验 if(os!=null){os.close()}
    os.close();
    is.close();
}

JDK7:

try(
	   //创建一个字节输入流
   InputStream is =new FileInputStream("D://img.jpg");
    //创建一个字节输出流和目标文件接通
    OutputStream os =new FileOutPutStream("D://a.txt");
){
   //定义一个字节数组
    byte[] buffer = new byte[1024];
    int len ;记录读取数据的字节数
        while(len=is.read(buffer)!=-1){
            os.write(buffer,0,len);
        }
    //关闭流
    os.close();
    is.close();
}catch (Exception ex){
    e.printStackTrace();
}

JDK9:

不好

字符流

  • Reader
    • FileReader
  • Writer
    • FileWriter
Reader fr=new FileReader("D://img.txt");
Writer fw=new FileWriter("D://a.txt");
int code = fr.read();//每次读取一个字符 没有返回-1

FileReader

  • public FileReader(File file)
  • public FileReader(String pathname)

常用方法:

  • public int read()每次读取一个字符 没有返回-1
  • public int read(char[] buffer)每次读取一个字符数组 没有返回-1

问题:

  • 中文不会乱码
  • 性能较慢

Filewrite

  • public FileWriter(File file)
  • public FileWriter(File file,boolean append)
  • public FileWriter(String pathname)
  • public FileWriter(String pathname,boolean append)

常用方法:

  • public void write(int c)
  • public void write(char[] cbuf)
  • public void write(char[] cbuf,int off,int len)写一部分
  • public void write(String str)
  • public void write((String str,int off,int len)
  • flush()
  • close()
Write fw =new FileWrite("D://img.jpg");
fw.write('s');

缓冲流

自带缓冲区,提高原始流的性能

  • BufferedInputStream
  • BufferedOutputStream
  • BufferedReader
  • BufferedWriter

自带了8kb的缓冲池

字节缓冲流

构造器:

  • public BufferedInputStream (InputStream is)
  • public BufferedOutputStream(OutputStream os)
try(
	   //创建一个字节输入流
   InputStream is =new FileInputStream("D://img.jpg");
    BufferedInputStream bis =new BufferedInputStream(is);
    //创建一个字节输出流和目标文件接通
    OutputStream os =new FileOutPutStream("D://a.txt");
    BufferedOutputStream ois=new BufferedOutputStream(os);
){
   //定义一个字节数组
    byte[] buffer = new byte[1024];
    int len ;记录读取数据的字节数
        while(len=bis.read(buffer)!=-1){
            bos.write(buffer,0,len);
        }
}catch (Exception ex){
    e.printStackTrace();
}

字符缓冲流:

  • public BufferedReader (Read is)
  • public BufferedWriter(Writer os)

新增输入流方法:

  • public String readLine() 读取一行数据,如果没有完毕,无行课读取返回null

输出流:

  • public void newLine() 换行操作

转换流

不同编码读取会乱码

  • 使用字符输入转换流
  • 先提取原始的字节流
  • 然后在将字节流转换成对应的编码格式

转换流:

  • InputStreamReader
  • OutputStreamWriter

构造器:

  • public InputStreamReader (InputStream is)
  • public InputStreamReader(InputStream is,String charset)

字符输出转换流:

  • public OutputStreamWriter (OutputStream os)
  • public OutputStreamWriter(OutputStream os,String charset)

序列化对象

对象字节输出流

ObjectOutputStream

对象字节输入流

ObjectInputStream

构造器:

  • public ObjectOutputStream (OutputStream os)
  • public ObjectInputStream (InputStream is)
//对象系列化
//实体类要实现接口
Serialiazble
Student st =new Student (...);
ObjectOutputStream  oos = new ObjectOutputStream (new FileOutputStream("D://a.txt"));
//调用序列化方法
oos.writeObject(st);
oos.close();
//对象反序列化
 ObjectInputStream  ois = new  ObjectInputStream(new FileOutputStream("D://a.txt"));
//调用序列化方法
  Student st=(  Student)ois.readObject(st);
  ois.close();

不想序列化

//实体类属性字段加
private transient String password;

打印流

字节输出流;

PrintStream

字符输出流

PrintWriter

PrintStream

构造器:

  • public PrintStream(OutputStream os)
  • public PrintStream(File file)
  • public PrintStream(String filePath)

方法:

  • public void print(XXX xxx)

PrintWriter

构造器:

  • public PrintWriter(OutputStream os)
  • public PrintWriter(File file)
  • public PrintWriter(String filePath)

方法:

  • public void print(XXX xxx)
 PrintStream ps =new  PrintStream("D://s。text");

Propreties

  • 是一个Map集合,但是HashMap更好用

存放键值对的信息

Propreties ps =new Propreties();
ps.setPropreties("admin","123456");
ps.put("password","123456");
ps.store(new FileWriter("D://a.txt","give me 100"));
//路径,心得
//加载属性到Propreties对象中
ps.load(new FileReader("D://a.txt"));
ps.get("admin");
ps.getPropreties("admin");

IO框架

我醉了经典白学

commonis-io

FileUtils

  • String readFileToString(File file,String encoding) 读取文件中的数据,返回字符串
  • void copyFile(File srcfile,File destFile) 复制文件
  • void copyDirectoryToDirectory(File srcDir,File destDir) 复制文件夹

NIO

Files.copy(Path.of(""),Path.of(""));
Files.deleteIfExists(Path.of(""))

这篇关于javaEE(Stream流、日志、IO流、File)的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!