热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

File类递归

1.File类:文件和目录路径名的抽象表现形式2.创建对象:File(Stringpathname)通过给定的路径创建文件对象File(Stringpa

1.File类:文件和目录路径名的抽象表现形式

2.创建对象: File(String pathname) 通过给定的路径创建文件对象

         File(String parent, String child) /File(File parent, String child)

3. 常用方法:

1 》 exists() 判断文件或目录是否在硬盘上存在。 true 表示存在。

 

代码示例:

1 public class File 类 {
2 public static void main(String[] args) {
3 File f=new File("d:\\s\\1.txt");
4 File f1=new File("d:/1.txt");
5 File f2=new File("a.txt");
6 // System.out.println(f.exists());
7 // System.out.println(f2.getAbsolutePath());
8 }
9 }

 

文件的常用方法:

1 常用方法:
2 1.exists() 判断文件或目录是否在硬盘上存在。 true 表示存在
3 2.createNewFile() 创建一个文件,如果该文件已经存在,返回 false ,如果创建成功,返回 true
4 3.mkdirs() /mkdir() 创建文件夹,加 s 表示父目录可以不存在,不加,必须存在,才能创建成功
5 4.delete() /deleteOnExit() 删除文件或目录 /jvm 退出时删除
6 注意: 删除可以删除文件或者空目录。

 代码示例:

1 public class File 类的常用方法 {
2 public static void main(String[] args) throws IOException {
3 File f=new File("d:\\s\\1.txt");
4 File f1=new File("d:\\s\\2");
5 File f2=new File("d:\\s\\a\\3");
6 // System.out.println(f.createNewFile());
7 // System.out.println(f1.createNewFile());
8 // System.out.println(f2.mkdirs());
9 // System.out.println(f1.delete());
10 System.out.println(f2.delete());
11 }
12 }

 

 文件的常用方法:

1 1.getAbsoluteFile() /getAbsolutePath() 获取文件或目录的绝对路径
2 2.getName() 返回文件或目录的名称,包括后缀名
3 3.getPath() 返回文件或目录的路径表示形式。
4 4.getParent() /getParentFile() 获取文件或目录的父目录
5 **5.isDirectory() /isFile() 判断是否为目录 / 文件 前提是该文件或目录必须存在,才能判断,否则都返回 fals
6 e 。
7 6.lastModified() 返回文件或目录的最后一次修改时间 返回值为毫秒值 long 类型
8 7.length() 返回文件的长度,如果文件不存在,返回值为 0 如果文件存在,返回值为文件的长度,如果为目录,值不
9 确定。

 

代码示例:

1 public class File 的常用方法一 {
2 public static void main(String[] args) {
3 File file=new File("1.txt");
4 File file1=new File("d:\\a\\1.txt");
5 /* System.out.println(file.getAbsolutePath());
6 System.out.println(file.getName());
7 System.out.println(file.getPath());
8 System.out.println(file1.getName());
9 System.out.println(file1.getPath());*/
10 File f2=new File("d:\\s\\a.txt");
11 // System.out.println(f2.isDirectory());
12 // System.out.println(f2.isFile());
13 // 最后一次修改时间
14 // System.out.println(new Date(f2.lastModified()));
15 System.out.println(f2.length());
16 System.out.println(new File("d:\\s").length());
17 }
18 }

 

1 *** 1.list() /listFiles() 遍历文件夹
2 注意:
3 ① 只能遍历出该父目录下的直接子目录和子文件,不能再继续遍历,并且不包含该父目录。
4 ② 如果该父目录不是一个目录,或者不存在 都返回 null ,所以在遍历的时候,需要判断数组是否为 null
5 再进行遍历。
6 代码演示
7 public class File 类的常用方法二 {
8 public static void main(String[] args) {
9 File file=new File("d:\\s");
10 File[] arr = file.listFiles();
11 if (arr!=null) {
12 for (File file2 : arr) {
13 System.out.println(file2);
14 }
15 }
16 }
17 }

 

 

递归:自己调用自己

1 注意 :
2 ① 递归必须有出口。没有出口会导致栈溢出
3 ② 递归的分类:
4 1 》 直接递归
5 例如: A 自身在 A 方法中被调用。
6 2 》间接递归
7 例如: A 在 B 方法中使用, B 方法又在 C 方法中使用。。 C 方法中又调用了 A 方法。
8 2. 用递归 ,加法 求 1-10 的和
9 代码演示:
10 public class 递归 {
11 public static void main(String[] args) {
12 System.out.println(getSum(5));
13 }
14 // 用递归 ,加法 求 1-10 的和
15 public static int getSum(int n) {
16 // 当 n=1 和就是 1
17 if(n==1) {
18 return 1;
19 }
20 return getSum(n-1)+n;
21 }
22 }

 

递归中的兔子问题(斐波那契数列)

1 有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少
2
3 n=3 n=(n-1)+(n-2)
4 1, 1, 2, 3, 5, 8, 13, 21, 34, 55, 89, 144, 233,377,610,987,1597,2584,4181,6765,10946,17711,28657,46368

 

利用递归:

代码示例:

1 package com.niubi;
2
3 public class Demo12 {
4
5 public static void main(String[] args) {
6
7 System.out.println("第十二个月共有"+getRabbit(12)+"只兔子");
8 //假设求第十二个月总共有多少对兔子
9 }
10 public static int getRabbit(int n) {
11 if(n==1||n==2) {
12 return 1;
13 }
14 else {
15 return getRabbit(n-1)+getRabbit(n-2);
16 }
17 }
18
19 }

 

执行结果:

 


转载于:https://www.cnblogs.com/ywzbky/p/10685746.html


推荐阅读
  • 深入解析Java枚举及其高级特性
    本文详细介绍了Java枚举的概念、语法、使用规则和应用场景,并探讨了其在实际编程中的高级应用。所有相关内容已收录于GitHub仓库[JavaLearningmanual](https://github.com/Ziphtracks/JavaLearningmanual),欢迎Star并持续关注。 ... [详细]
  • Nginx 反向代理与负载均衡实验
    本实验旨在通过配置 Nginx 实现反向代理和负载均衡,确保从北京本地代理服务器访问上海的 Web 服务器时,能够依次显示红、黄、绿三种颜色页面以验证负载均衡效果。 ... [详细]
  • 深入解析Java虚拟机(JVM)架构与原理
    本文旨在为读者提供对Java虚拟机(JVM)的全面理解,涵盖其主要组成部分、工作原理及其在不同平台上的实现。通过详细探讨JVM的结构和内部机制,帮助开发者更好地掌握Java编程的核心技术。 ... [详细]
  • 开发笔记:2020 BJDCTF Re encode
    开发笔记:2020 BJDCTF Re encode ... [详细]
  • 开发笔记:9.八大排序
    开发笔记:9.八大排序 ... [详细]
  • 本题探讨了在一个有向图中,如何根据特定规则将城市划分为若干个区域,使得每个区域内的城市之间能够相互到达,并且划分的区域数量最少。题目提供了时间限制和内存限制,要求在给定的城市和道路信息下,计算出最少需要划分的区域数量。 ... [详细]
  • 本文详细探讨了HTML表单中GET和POST请求的区别,包括它们的工作原理、数据传输方式、安全性及适用场景。同时,通过实例展示了如何在Servlet中处理这两种请求。 ... [详细]
  • JavaScript 基础语法指南
    本文详细介绍了 JavaScript 的基础语法,包括变量、数据类型、运算符、语句和函数等内容,旨在为初学者提供全面的入门指导。 ... [详细]
  • 本文将探讨Java编程语言中对象和类的核心概念,帮助读者更好地理解和应用面向对象编程的思想。通过实际例子和代码演示,我们将揭示如何在Java中定义、创建和使用对象。 ... [详细]
  • 本文详细介绍了优化DB2数据库性能的多种方法,涵盖统计信息更新、缓冲池调整、日志缓冲区配置、应用程序堆大小设置、排序堆参数调整、代理程序管理、锁机制优化、活动应用程序限制、页清除程序配置、I/O服务器数量设定以及编入组提交数调整等方面。通过这些技术手段,可以显著提升数据库的运行效率和响应速度。 ... [详细]
  • 本文深入探讨了SQL数据库中常见的面试问题,包括如何获取自增字段的当前值、防止SQL注入的方法、游标的作用与使用、索引的形式及其优缺点,以及事务和存储过程的概念。通过详细的解答和示例,帮助读者更好地理解和应对这些技术问题。 ... [详细]
  • 本题来自WC2014,题目编号为BZOJ3435、洛谷P3920和UOJ55。该问题描述了一棵不断生长的带权树及其节点上小精灵之间的友谊关系,要求实时计算每次新增节点后树上所有可能的朋友对数。 ... [详细]
  • 实用正则表达式有哪些
    小编给大家分享一下实用正则表达式有哪些,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下 ... [详细]
  • 本文介绍了如何使用JavaScript的Fetch API与Express服务器进行交互,涵盖了GET、POST、PUT和DELETE请求的实现,并展示了如何处理JSON响应。 ... [详细]
  • 深入解析SpringMVC核心组件:DispatcherServlet的工作原理
    本文详细探讨了SpringMVC的核心组件——DispatcherServlet的运作机制,旨在帮助有一定Java和Spring基础的开发人员理解HTTP请求是如何被映射到Controller并执行的。文章将解答以下问题:1. HTTP请求如何映射到Controller;2. Controller是如何被执行的。 ... [详细]
author-avatar
ningxiao088_272
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有