day15File类,递归,字节流

磁盘存储机制:

在用户界面录入数据,临时存储到内存条中(快,但内存小),在通过访问硬盘,永久存储到硬盘上(慢,但容量大)


File类


概念:

java.io.File(类),磁盘读写最基本的类,它可以代表磁盘上的一个文件或者一个目录(文件夹)

File类里面有一些方法,可以获取磁盘上文件,目录(文件夹)的属性信息(大小,最后修改时间,是否可读,是否可写,创建文件/目录(文件夹),删除文件/目录(文件夹)等操作)

但是:

不能读写文件内容,需要使用/配合使用//todoIO流进行读写

目录(文件夹):一个逻辑结构,可以把文件进行分类管理


构造方法:

1)File(String pathname)通过将给定的路径字符串转换为抽象路径名来创建新的File实例:

2)File(String parent,String child)从父路径名字符串和子路径名字符串创建信的File实例

3)File(File parent,String child)从父抽象路径名和子路径名字符串创建新的File实例

pathname:

绝对路径(指带盘符的"D:\\demo.txt"或者(D:/demo.txt)),

盘符大小写都可以

相对路径("demo.txt",从项目根目录开始找)

parent和child:

在多级目录下,从中间任意一处分割都可以


转义字符:

\t    \"    \'    \\    \b    \f    \r    \n


File常用的方法

1)public String getAbsolutePath():获取此File的使用绝对路径名字字符串

    无论文件/目录存不存在,都会返回一个字符串

2)public String getPath():返回此File构造时路径的字符串

     无论文件/目录存不存在,都会返回一个字符串

3)public String getName():返回由此File表示的文件或目录的具体名称

    无论文件/目录存不存在,都会返回一个字符串,最后一部分

4)public long length():返回由此File表示的文件的长度,不能获取目录长度

    只能获取文件大小,单位是字节

    无论文件存不存在,都会返回数值,文件不存在返回0字节

    获取目录的时候,返回0或者其他数字(假的),没意义,但也不报错


File判断功能的方法

1).public boolean exists() :此File表示的文件/目录是否实际存在。

2).public boolean isDirectory() :此File表示的是否为目录。

3).public boolean isFile() :此File表示的是否为文件。


File类常用创建和删除的方法

需要抛出IO异常,编译器异常

1).public boolean createNewFile():当具有该名称的文件不存在时,创建一个新的空文件。

        一般先去判断文件是否存在

2).public boolean mkdir():创建由此File表示的单级目录。

        带.txt结尾的也可以是文件,一般需要先去判断是否存在

3).public boolean mkdirs():创建由此File表示的多级目录,包括任何必需但不存在的父目录。

        创建多级目录"a\\b\\c\\d",带:号的是盘符,直接\\或者/的是父目录,一般需要先去判断是否存在

4).public boolean delete():删除由此File表示的文件或”空目录”。

        不能删除非空目录,返回false


File类的列表常用方法

会找出隐藏文件,隐藏文件只是windows给加的属性,在磁盘真实存在

1). public String[] list​():获取此目录下所有“子文件/子目录”的“名称数组”。

        一般先判断是否是一个目录,不是目录的话,返回null空指针

        会根据hash表自动排序,不要通过是否有后缀判断是文件还是目录

2). public File[] listFiles​():获取此目录下所有“子文件/子目录”的“File[]数组”。

        返回的是File[]数组,就可以通过遍历之后的isFile()或者isDirectory()来判断是文件还是目录


递归


概念:

全称为:方法的递归调用——就是指方法自己调用本身


注意事项:

1)递归的层次不能太深,否则会造成"栈溢出"

2)递归一定要有出口.否则称之为死递归,最终导致"栈溢出"

3)构造方法不能递归调用


使用场景:

当在方法中,做一些处理后,发现还需要执行此方法的流程,这时就可以再次的调用本方法。利用递归的特性,从未知递归的查找到已知,然后再从已知往回计算。


IO流

字节流

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容