12 File文件对象:创建、获取基本信息、遍历文件夹、查找文件;字符集的编解码 (黑马Java视频笔记)

在这里插入图片描述

文章目录

    • File >> 存储数据的方案
      • 1. 认识File
      • 2. File操作
        • 2.1 创建File对象
        • 2.2 File操作
          • 1)对文件对象的信息的操作
          • 2)文件/文件夹的创建/删除
          • 3)⭐⭐对文件夹的遍历
      • 3. 方法递归
        • 3.1 认识递归
        • 3.2 递归算法及其执行流程
          • 1) 案例:
          • 2) 递归算法的三要素:
          • 3) 🤔练习:猴子吃桃问题
        • 3.3 ⭐递归实现文件搜索
      • 4. 字符集
        • 4.1 常见字符集介绍
        • 4.2 字符集的编码、解码操作
          • 1)编码
          • 2)解码

File >> 存储数据的方案

1. 认识File

开发中需要长久保存的数据,可以保存在磁盘的文件中,即使断电后也不会丢失

  • Filejava.io.包下的类,File类的对象,用于代表当前操作系统的文件(可以是文件、或文件夹),只能操作文件本身

2. File操作

2.1 创建File对象
  • File file = new File("文件/文件夹/绝对路径/相对路径");
// public File(String pathname):通过将给定的路径名字符串转换为表示绝对路径名字符串来创建一个新File实例。
// public File(String parent, String child):从父路径名字符串和子路径名字符串创建一个新File实例。
// public File(File parent, String child):从父目录和子路径名字符串创建一个新File实例。
// File f11 = new File("F:\\Pictures\\江晏.png"); 反斜杠的路径:双反斜杠
File f1 = new File("F:/Pictures/江无浪.png");
2.2 File操作
1)对文件对象的信息的操作
System.out.println(f1.getName());       // 文件名
System.out.println(f1.getParent()); //  父路径
System.out.println(f1.getPath());   // 路径System.out.println(f1.length());        // 字节个数
System.out.println(f1.lastModified());  // 最后修改时间
System.out.println(f1.isFile());    // 是否是文件
System.out.println(f1.isDirectory()); // 是否是文件夹// 可以使用相对路径定位文件对象
// 只要带有盘符的路径都称之为绝对路径
// 相对路径:不带盘符,默认是到你的idea工程下直接寻找文件的。一般用来找工程下的项目文件的
System.out.println(f1.getAbsolutePath());   // 绝对路径
2)文件/文件夹的创建/删除
// 3、创建对象代表不存在的文件路径\文件夹
File f2 = new File("F:/Users/Juzi/Pictures/江晏1.png");
System.out.println(f2.exists());    // 判断文件是否存在
System.out.println(f2.createNewFile()); // 创建文件// 4、创建对象代表不存在的文件夹
// mkdir():创建单级文件夹
File dir1 = new File("F:/Users/Juzi/Pictures/dir1");
System.out.println(dir1.mkdir());
// mkdirs():创建多级文件夹
File dir2 = new File("F:/Users/Juzi/Pictures/dir1/dir2/dir3");
System.out.println(dir2.mkdirs());// 5、创建File对象代表存在的文件,然后删除它
File f3 = new File("F:/Users/Juzi/Pictures/江晏.png");
System.out.println(f3.delete());// 6、创建File对象代表存在的文件夹,然后删除它
// 只能删除空文件夹
File dir3 = new File("F:/Users/Juzi/Pictures/dir1");
System.out.println(dir3.delete());
3)⭐⭐对文件夹的遍历

在这里插入图片描述

💡可以通过获取的文件对象数组是长度为0还是为null,来判断该文件夹是为空还是没有权限访问,从而采取措施提高代码的健壮性。

// 7、遍历文件夹的方法
// public String[] list():获取当前目录下的所有子项,以字符串数组的形式返回。
// public File[] listFiles():获取当前目录下的所有子项,以File数组的形式返回。
File names = new File("F:/Users/Juzi/Pictures");
String[] namelist = names.list();
for (String name : namelist){System.out.println(name);
}
// 获取的是文件对象,然后可以操作文件
File[] files = names.listFiles();
for (File file : files){System.out.println(file);
}

3. 方法递归

3.1 认识递归
  • 一种算法
  • 从形式上:方法调用自身的形式 >>> 递归
    • 直接递归:方法自己调用自己
    • 间接递归:方法调用其他方法,其他方法又回调方法自己
  • 需注意的问题:
    • 递归如果没有控制好终止,会出现递归死循环,导致栈内存溢出错误
public static void main(String[] args) {// 目标:认识递归的形式print(3);
}public static void print(int n) {if (n > 0) {print(n - 1);   // 递归调用:自己调自己System.out.print(n + "\t");}
}

3.2 递归算法及其执行流程
1) 案例:
  • 需求:计算n的阶乘
  • 分析
    • 公式:f(n) = 1 * 2 * 3 * 4 * ...(n-1) * n;
    • 递归写法:f(n) = f(n-1) * n
public static void main(String[] args) {// 目标:计算n的阶乘System.out.println(factorial(5));	// 120
}public static int factorial(int n) {if (n == 1) {return 1;}return n * factorial(n - 1);
}
  • 递归调用的流程

先一层一层入栈,再一层一层出栈

在这里插入图片描述

2) 递归算法的三要素:
  • 递归公式:f(n) = f(n-1) * n
  • 递归的终结点:f(1)
  • 递归的方向必须走向终结点
3) 🤔练习:猴子吃桃问题

猴子第一天摘下若干个桃子,当即吃了一半,还不过瘾,又多吃了一个,第二天早上又将剩下的桃子吃掉一半,又多吃了一个。以后每天早上都吃前一天剩下的一半零一个。到第10天早上想再吃时,见只剩下一个桃子了。

求第一天共摘多少个桃子?

分析:

  • 每天都是同一个事件:当天桃子数量的一半 + 1

  • 递归公式:
    f ( n + 1 ) = f ( n ) − f ( n ) / 2 − 1 → f ( n ) = 2 f ( n + 1 ) + 2 f(n+1) = f(n)-f(n)/2-1 \quad →f(n) = 2f(n+1) + 2 f(n+1)=f(n)f(n)/21f(n)=2f(n+1)+2

  • 递归的终结点:f(10) = 1

  • 递归的方向必须走向终结点

public static void main(String[] args) {// 猴子吃桃System.out.println(peachCount(1));  // 1534// 第一天的桃子数量 peachCount(1)
}public static int peachCount(int day){if(day == 10){return 1;}return (peachCount(day + 1) + 1) * 2;
}

在这里插入图片描述

3.3 ⭐递归实现文件搜索
  • 需求:从E:盘中,搜索 “ QQ.exe ” 文件,找出后输出其位置

  • 分析:

    • 先找出E:盘下的所有一级文件对象
    • 遍历全部一级文件对象,判断是否是文件
      • 是文件 → 判断是否是自己想要的
      • 是文件夹,需要继续进入到该文件夹,重复上述过程
public static void main(String[] args) {// 目标:完成文件搜索// 1、定义一个方法,实现文件搜索功能。// 2、在main方法中调用该方法,并测试。File dirPath = new File("E:/");searchFile(dirPath, "QQ.exe");
}/*** 递归实现文件搜索* @param dirPath 搜索的目录路径* @param fileName 要搜索的文件名*/
public static void searchFile(File dirPath, String fileName){// 1、判断极端情况: 判断当前目录是否存在,并且是文件夹,并且不是文件// ① 当前目录是否有权限访问 || ② 当前目录是否存在 || ③ 当前目录是否是文件if(dirPath == null || !dirPath.exists() || dirPath.isFile()){System.out.println("搜索的文件不存在!");return;}// 2、获取目录下的所有一级文件或者文件夹对象File[] files = dirPath.listFiles();// 2.1 考虑极端情况:判断当前目录下是否存在一级文件对象,存在才可以遍历// files != null  》》》 当前目录有权限拿// files.length > 0   》》》 当前目录有一级文件对象if(files!=null && files.length>0){// 3、遍历一级文件对象,判断是文件还是文件夹for (File file : files){if(file.isFile()){// 4、判断文件名是否匹配if(file.getName().contains(fileName)){System.out.println("找到文件:" + file.getAbsoluteFile());}}else{// 5、递归搜索子文件夹searchFile(file, fileName);}}}
}

📓关于 if 条件语句中的判断 >>> 遍历文件的 listfiles() 方法中各返回值的明细

4. 字符集

4.1 常见字符集介绍
  • 标准ASCII字符集
    • 包含英文、符号等
    • 使用1个字节(8位)存储一个字符,首位是0,总共可表示128个字符
  • GBK(汉字内码扩展规范,国标)
    • 汉字编码字符集,包含2万多个汉字等字符,GBK中一个中文字符编码成两个字节的形式存储
    • GBK兼容了ASCII字符集
    • 汉字的第一个字节的第一位必须是1
  • Unicode字符集(统一码)
    • 国际组织制定的,可以容纳世界上所有文字、符号的字符集
  • UTF-8字符集:
    • Unicode字符集的一种编码方案
    • 采用可变长编码方案:前缀码
      • 共四个长度区:1个字节(英文、数字),2个字节,3个字节(汉字),4个字节

可变长编码

4.2 字符集的编码、解码操作

⚠️字符编码时使用的字符集,和解码时使用的字符集必须一致,否则会出现乱码

⚠️英文、数字一般不会乱码,因为很多字符集兼容了ASCII码

1)编码

getBytes()方法:将字符串转换为字节数组

getBytes(String charsetName):指定编码方式,将字符串转换为字节数组

String str = "你好";byte[] bytes = str.getBytes();  // 默认使用UTF-8编码
System.out.println(bytes.length);   // 6
System.out.println(Arrays.toString(bytes)); // [-28, -67, -96, -27, -91, -67]byte[] gbks = str.getBytes("GBK");
System.out.println(gbks.length);    // 4
System.out.println(Arrays.toString(gbks));  // [-60, -29, -70, -61]
2)解码

String(byte[] bytes):默认使用UTF-8解码

String(byte[] bytes, String charsetName):指定编码方式,将字节数组解码为字符串

String str2 = new String(bytes);
System.out.println(str2);   // 你好String str3 = new String(gbks, "GBK");
System.out.println(str3);   // 你好

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/35759.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

逻辑派G1 6层高速板学习

逻辑派G1 6层高速板学习 一、原理图分析二、电源分析三、网表导入四、板框导入五、PCB快捷键导入与设置六、模块抓取以及接口器件布局七、模块化布局--预布局(先放各模块中的大器件)1 HDMI模块布局2 MCU模块布局3 FPGA模块布局4 DDR3模块布局5 DCDC电源模…

图论——广度优先搜索实现

99. 岛屿数量 题目描述 给定一个由 1(陆地)和 0(水)组成的矩阵,你需要计算岛屿的数量。岛屿由水平方向或垂直方向上相邻的陆地连接而成,并且四周都是水域。你可以假设矩阵外均被水包围。 输入描述 第一行包含两个整数 N, M,表示矩阵的行数和列数。 后续 N 行,每行…

PTS-G1K13M RF Generator 1kW / 13MHz User’s Manual 手侧

PTS-G1K13M RF Generator 1kW / 13MHz User’s Manual 手侧

应用分层简介

一、什么是应用分层 应用分层是一种软件开发设计思想,它将应用程序分为多个层次,每个层次各司其职,多个层次之间协同提供完整的功能,根据项目的复杂程度,将项目分为三层或者更多层。 常见的MCV设计模式,就…

conda的基本使用及pycharm里设置conda环境

创建conda环境 conda create --name your_env_name python3.8 把your_env_name换成实际的conda环境名称,python后边的根据自己的需要,选择python的版本。 激活conda环境 conda activate your_env_name 安装相关的包、库 conda install package_name …

E902基于bash与VCS的仿真环境建立

网上看见很多E902仿真的文章,但用到的编译器是类似于这种Xuantie-900-gcc-elf-newlib-x86_64-V3.0.1-20241120,而我按照相应的步骤与对应的编译器,仿真总会报错。后面将编译器换成riscv64-elf-x86_64-20210512,反而成功了。现在开…

PostgreSQL:简介与安装部署

🧑 博主简介:CSDN博客专家,历代文学网(PC端可以访问:https://literature.sinhy.com/#/?__c1000,移动端可微信小程序搜索“历代文学”)总架构师,15年工作经验,精通Java编…

Git使用和原理(3)

1.远程操作 1.1分布式版本控制系统 我们⽬前所说的所有内容(⼯作区,暂存区,版本库等等),都是在本地!也就是在你的笔记本或者 计算机上。⽽我们的 Git 其实是分布式版本控制系统!什么意思呢&a…

ssm框架之mybatis框架讲解

1,Mybatis 1.1 Mybatis概述 1.1.1 Mybatis概念 MyBatis 是一款优秀的持久层框架,用于简化 JDBC 开发 MyBatis 本是 Apache 的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google code,并且改名为MyBatis 。2…

方法之笔,驭繁于简.绘场景之魂——方法论引领支撑透明化项目之航

关注作者 项目建设中痛难点剖析: 01 项目策划有缺失,目标风险难管控 ①目标设定不合理,由于项目移交交底不充分,造成项目建设目标与前期立项论证偏差过大,达不到建设预期; ②风险评估不足,未…

【Apache Storm】

一、Storm简介 1、概述 官网地址:https://storm.apache.org/index.html Apache Storm 是一个开源的、分布式的实时计算系统,专为处理流式数据而设计。它能够处理大量数据流并在极低的延迟下提供实时的结果。相比于传统的批处理系统,Storm 具…

【力扣刷题实战】无重复的最长字串

大家好,我是小卡皮巴拉 文章目录 目录 力扣题目: 无重复的最长字串 题目描述 解题思路 问题理解 算法选择 具体思路 解题要点 完整代码(C) 兄弟们共勉 !!! 每篇前言 博客主页&#x…

联想扬天M590台式机开机卡LOGO不引导故障维修案例分享

故障描述: 用户送修联想扬天M590台式机到站端维修,说是开机不能正常进系统;站端检测开机后卡LOGO、无法加载引导系统; 故障检修: 插拔内存、插拔硬盘,更换内存、更换硬盘均不能解决此故障;调试…

C++刷题(三):string

📝前言说明: 本专栏主要记录本人的基础算法学习以及刷题记录,使用语言为C。 每道题我会给出LeetCode上的题号(如果有题号),题目,以及最后通过的代码。没有题号的题目大多来自牛客网。对于题目的…

PosterRender 实现微信下程序 分享商品生成海报

PosterRender 是什么 PosterRender 是一种专注于生成高质量海报图像的技术或工具,常用于生成静态图片,特别是适合用于营销、宣传和展示的图形设计。它通常用于在服务端或客户端渲染复杂的图像,包括文字、图形、图标、背景等,生成…

Spring Cloud Stream - 构建高可靠消息驱动与事件溯源架构

一、引言 在分布式系统中,传统的 REST 调用模式往往导致耦合,难以满足高并发和异步解耦的需求。消息驱动架构(EDA, Event-Driven Architecture)通过异步通信、事件溯源等模式,提高了系统的扩展性与可观测性。 作为 S…

Houdini制作非均匀细分的柱体

近期看见一非均匀细分的做法,觉得不错将其拆开以笔记分享。效果如下: 1.创建Geometry节点,并在该节点内部创建line节点样条线,设置合适长度并添加resample节点。 2.此时若无法看见顶点与顶点编号显示,可按快捷键D&am…

C# Unity 唐老狮 No.10 模拟面试题

本文章不作任何商业用途 仅作学习与交流 安利唐老狮与其他老师合作的网站,内有大量免费资源和优质付费资源,我入门就是看唐老师的课程 打好坚实的基础非常非常重要: Unity课程 - 游习堂 - 唐老狮创立的游戏开发在线学习平台 - Powered By EduSoho C# 1. 内存中,堆和…

Nuxt2 vue 给特定的页面 body 设置 background 不影响其他页面

首先认识一下 BODY_ATTRS 他可以在页面单独设置 head () {return {bodyAttrs: {form: form-body}};},设置完效果是只有这个页面会加上 接下来在APP.vue中添加样式

拥抱健康养生,开启活力生活

在快节奏的现代社会,健康养生不再是一句口号,而是我们对高品质生活的追求。它贯穿于日常的点点滴滴,对我们的身心状态有着深远影响。 饮食养生是基础。秉持均衡原则,每日的餐盘应是色彩斑斓的。新鲜蔬菜富含维生素与膳食纤维&…