java核心内库---IO(1)

2023-10-10 16:50
文章标签 java 核心 io 内库

本文主要是介绍java核心内库---IO(1),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

java的集合框架:类和接口存在于java.util包中

java的IO:          类和接口存在于java.io包中

//File类指的是文件/目录

File类的介绍和路径分割符:

File类是IO包中唯一表示磁盘文件磁盘目录的对象的路径

该类包含了创建,删除文件,重命名文件,判断文件,读写权限以及文件是否存在,查询等功能方法

只能设置和获取文件本身的信息,不能设置和获取文件的内容

在java开发中:

Unix系统严格区分大小写

Windows系统不区分大小写

不同系统路径分割符和属性分隔符不同

Unix系统:     使用"/"来分割目录路径  使用":"来分割属性

Window系统: 使用"\"来分割一般路径,但是在java中一个"\"代表转义,在Windows平台的java代码中表示路径,就得使用两个反斜线"\\"来表示,第一个反斜线代表转义,第二个反斜线才代表反斜线的意思,但是,Windows系统也支持"/"来分割路径,使用";"分割属性

//为了方便,统一使用"/"来分割目录路径

如果以后不知道在哪个平台上运行,该如何解决编写分隔符的问题?此时File类中提供了两类静态常量,它们可以根据不同的系统,产生系统相对应的分隔符

//两类常量,每一类的两个常量是等价的
 第一类:路径分隔符
        static String pathSeparator    与系统有关的路径分隔符,为了方便,它被表示为一个字符串。     
        static char pathSeparatorChar  与系统有关的路径分隔符。 
 第二类:属性分割符
        static String separator        与系统有关的默认名称分隔符,为了方便,它被表示为一个字符串。 

        static char separatorChar      与系统有关的默认名称分隔符。 

File类中重写了toString()方法,所以输出File对象则输出的是路径

源码如下:

public String toString() {
        return getPath();

    }

File类中获取文件路径的方法:

     

// 操作File路径和名称,该文件可以不存在,因为它只代表的是一个路径而已
File getAbsoluteFile() :获取绝对路径
String getAbsolutef1ath() :获取绝对路径
String getPath() :获取文件路径
String getName() :获取文件名称
File  getparentFile() :获取上级目录文件
String getparent() :获取上级目录文件路径

File类中检测状态的方法:

       boolean canExecute() :判断文件是否是可执行文件
       boolean canRead() :判断该文件是否可读
       boolean canWrite() :判断该文件是否可写
       boolean isHidden() :判断该文件是否为隐藏文件
       long lastModified() :获得该文件的最后修改时间

       long length() :获取该文件的长度大小(单个字符)

File类中文件操作的方法:

       boolean isFile() :是否是文件
       boolean createNewFile() :创建新的文件
       static File createTempFile(String prefix,String suffix) :创建临时文件
       boolean delete() :删除文件
       void deleteOnExit() :在JVM停止时删除文件

       boolean exists() :判断文件是否存在

File类中目录操作的方法:

       boolean isDirectory(): 判断是否为目录
       boolean mkdir(): 创建当前目录
       boolean mkdirs(): 创建当前目录和上级目录
       String[] list(): 列出所有文件名
       File[] list(): 列出所有文件对象
       static File[] listRoots(): 列出所有盘符

       boolean renameTo(File dest) :重新修改名称

IO流的分类和操作模板:

1.  IO流的分类,站在不同的角度上,分类分类方式是不同的

      1):根据流向划分:输入流和输出流

      2):根据数据的单位划分:字节流和字符流

      3):根据功能划分:节点流和包装流

2.  IO流的四大基流: 

       字节输入流(InputStream), 字节输出流(OutputStream), 字符输入流(Reader), 字符输出流(Writer)

注意:

       1).该四大基流均是抽象类,其他流都是继承于这四大基流,所以不能创建四大基流的对象,只能创建其子类对象

       2).无论是什么流,最后都必须用close方法关闭资源(如果操作文件,就得开通一个流对象关联我们的磁盘文件,如果不关闭资源,那么磁盘的文件一直被程序引用着,不能删除,也不能修改)

3.  操作IO流的模板:

       1).创建源或者目标对象

           以文件流为例:

           输入操作: 把文件中的数据流向程序当中,此时文件是源,程序是目标

           输出操作:把程序中的数据流向到文件中,此时文件是目标,程序是源

       2). 创建IO输入对象

           输入操作: 创建输入流对象

           输出操作: 创建输出流对象

       3). 具体的IO操作

           输入操作: 输入流对象的read方法 

           输出操作: 输出流对象的write方法

       4). 关闭资源(勿忘)

           输入操作: 输入流对象.close()

           输出操作: 输出流对象.close()

4. FileOutputStream写数据的方法:

       void write(int b);把一个字节写到文件中
       void write(byte[] b);把数组中所有的数据写入文件中

       void write(byte[] b,int off,int len);把数组b中从off索引开始的len个字节写到文件中


5. FileInputStream读数据的方法:

      //注意:如果读取到最后没有数据的时候,返回值为-1
      1. int read(); 读取一个字节 
      2. int read(byte[] b);读取多个字节,并存储到数组中,从数组索引为0的位置开始存,返回读取了几个字节, 输出的时候一般要用        len, len表示读取的实际的字节数

      方式2比方式1效率高,因为方式1每次才读一个字节,太慢了,方式2每次可以读取很多字节

6. 文件输出流实现换行和末尾追加

     换行符:

               针对不同的系统,里面的换行符号是不一样的

                            Windows: \r\n
                            Linux  : \n

                            mac    : \r

     末尾追加的方法:

                public FileOutputStream(File file,boolean append)
                                                    throws FileNotFoundException

         //布尔值为true则代表末尾追加,一般情况下,就是不写true,系统也会末尾追加 

7.文件的拷贝

文件的拷贝需要注意三点:

                 1). 如果该路径的目标文件不存在,则系统会先在该路径下创建这个文件,然后进行文件的拷贝

                 2). 如果打开文本文件,如果出现乱码则使用字节流,否则使用字符流

                 3). 读取一个字节写入一个字节可以解决乱码问题

实例如下:


8.文件名称过滤器

文件名称过滤器的两个高级方法:

          public String[] list(FilenameFilter filter)返回一个字符串数组,这些字符串指定此抽象路径名表示的目录中满足指定过滤器的文件和目录  

public File[] listFiles(FilenameFilter filter)返回抽象路径名数组,这些路径名表示此抽象路径名表示的目录中满足指定过滤器的文件和目录

注释:  文件过滤器的方法参数是一个接口,一般采用匿名内部类的方式实现,要重写该接口的accept方法,当且仅当该名称应该包含在文件列表中时返回 true;否则返回 false。

实例如下:

 

9.递归思想

方法递归的三个必要条件:
             1). 必须要有出口条件
             2). 必须满足一些规律

             3). 必须要有方法

实例如下:


这篇关于java核心内库---IO(1)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/181794

相关文章

Spring Boot整合Redis注解实现增删改查功能(Redis注解使用)

《SpringBoot整合Redis注解实现增删改查功能(Redis注解使用)》文章介绍了如何使用SpringBoot整合Redis注解实现增删改查功能,包括配置、实体类、Repository、Se... 目录配置Redis连接定义实体类创建Repository接口增删改查操作示例插入数据查询数据删除数据更

Java Lettuce 客户端入门到生产的实现步骤

《JavaLettuce客户端入门到生产的实现步骤》本文主要介绍了JavaLettuce客户端入门到生产的实现步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 目录1 安装依赖MavenGradle2 最小化连接示例3 核心特性速览4 生产环境配置建议5 常见问题

Java使用Swing生成一个最大公约数计算器

《Java使用Swing生成一个最大公约数计算器》这篇文章主要为大家详细介绍了Java使用Swing生成一个最大公约数计算器的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可以了解一下... 目录第一步:利用欧几里得算法计算最大公约数欧几里得算法的证明情形 1:b=0情形 2:b>0完成相关代码第二步:加

Java 的ArrayList集合底层实现与最佳实践

《Java的ArrayList集合底层实现与最佳实践》本文主要介绍了Java的ArrayList集合类的核心概念、底层实现、关键成员变量、初始化机制、容量演变、扩容机制、性能分析、核心方法源码解析、... 目录1. 核心概念与底层实现1.1 ArrayList 的本质1.1.1 底层数据结构JDK 1.7

Java Map排序如何按照值按照键排序

《JavaMap排序如何按照值按照键排序》该文章主要介绍Java中三种Map(HashMap、LinkedHashMap、TreeMap)的默认排序行为及实现按键排序和按值排序的方法,每种方法结合实... 目录一、先理清 3 种 Map 的默认排序行为二、按「键」排序的实现方式1. 方式 1:用 TreeM

Java中流式并行操作parallelStream的原理和使用方法

《Java中流式并行操作parallelStream的原理和使用方法》本文详细介绍了Java中的并行流(parallelStream)的原理、正确使用方法以及在实际业务中的应用案例,并指出在使用并行流... 目录Java中流式并行操作parallelStream0. 问题的产生1. 什么是parallelS

Java中Redisson 的原理深度解析

《Java中Redisson的原理深度解析》Redisson是一个高性能的Redis客户端,它通过将Redis数据结构映射为Java对象和分布式对象,实现了在Java应用中方便地使用Redis,本文... 目录前言一、核心设计理念二、核心架构与通信层1. 基于 Netty 的异步非阻塞通信2. 编解码器三、

SpringBoot基于注解实现数据库字段回填的完整方案

《SpringBoot基于注解实现数据库字段回填的完整方案》这篇文章主要为大家详细介绍了SpringBoot如何基于注解实现数据库字段回填的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以了解... 目录数据库表pom.XMLRelationFieldRelationFieldMapping基础的一些代

一篇文章彻底搞懂macOS如何决定java环境

《一篇文章彻底搞懂macOS如何决定java环境》MacOS作为一个功能强大的操作系统,为开发者提供了丰富的开发工具和框架,下面:本文主要介绍macOS如何决定java环境的相关资料,文中通过代码... 目录方法一:使用 which命令方法二:使用 Java_home工具(Apple 官方推荐)那问题来了,

Java HashMap的底层实现原理深度解析

《JavaHashMap的底层实现原理深度解析》HashMap基于数组+链表+红黑树结构,通过哈希算法和扩容机制优化性能,负载因子与树化阈值平衡效率,是Java开发必备的高效数据结构,本文给大家介绍... 目录一、概述:HashMap的宏观结构二、核心数据结构解析1. 数组(桶数组)2. 链表节点(Node