赶紧收藏!2024 年最常见 100道 Java 基础面试题(九)

上一篇地址:赶紧收藏!2024 年最常见 100道 Java 基础面试题(八)-CSDN博客

十七、Files的常用方法都有哪些?

Files是Java 7引入的java.nio.file包中的一个类,它提供了对文件和目录操作的实用方法。以下是Files类的一些常用方法:

  1. exists(Path path, LinkOption... options): 检查文件是否存在。LinkOption参数可以用来指定是否要考虑符号链接。

  2. notExists(Path path, LinkOption... options): 检查文件是否不存在,与exists相反。

  3. isRegularFile(Path path, LinkOption... options): 检查给定路径是否指向一个常规文件。

  4. isDirectory(Path path, LinkOption... options): 检查给定路径是否指向一个目录。

  5. createFile(Path path, FileAttribute<?>... attrs): 创建一个文件,如果文件已存在,则抛出FileAlreadyExistsException

  6. createDirectories(Path dir, FileAttribute<?>... attrs): 创建所有必需的非现有目录和子目录,不包括子路径,可以传入文件属性。

  7. delete(Path path): 删除文件。

  8. deleteIfExists(Path path): 如果文件存在,则删除它。

  9. move(Path source, Path target, CopyOption... options): 将文件从源路径移动到目标路径,可以指定复制选项,如是否覆盖目标文件。

  10. copy(Path source, Path target, CopyOption... options): 从源路径复制文件到目标路径,可以指定复制选项。

  11. readAllBytes(Path path): 读取文件的所有字节到字节数组中。

  12. readAllLines(Path path, Charset cs): 读取文件的所有行到字符串列表中,可以指定字符集。

  13. write(Path path, byte[] bytes, OpenOption... options): 将字节数组写入文件,可以指定打开文件的选项。

  14. write(Path path, Iterable<? extends CharSequence> lines, Charset cs, OpenOption... options): 将字符串序列写入文件,可以指定字符集和打开文件的选项。

  15. newDirectoryStream(Path dir, DirectoryStream.Filter<? super Path> filter): 打开一个目录,返回一个DirectoryStream,可以过滤和遍历目录中的文件。

  16. probeContentType(Path path): 尝试确定文件的MIME类型。

  17. getLastModifiedTime(Path path, LinkOption... options): 获取文件的最后修改时间。

  18. size(Path path): 返回文件的大小。

  19. isHidden(Path path): 检查文件是否是隐藏的。

  20. isReadable(Path path): 检查文件是否可读。

这些方法提供了对文件系统中的文件和目录进行各种操作的简便方式,包括文件的创建、删除、移动、复制、读取和写入等。

示例代码

import java.nio.file.Files;
import java.nio.file.Path;
import java.nio.file.Paths;
import java.io.IOException;
import java.nio.charset.Charset;
import java.nio.file.OpenOption;
import java.nio.file.attribute.FileAttribute;
import java.nio.file.CopyOption;
import java.nio.file.DirectoryStream;
import java.nio.file.DirectoryStream.Filter;

public class FilesExample {
    public static void main(String[] args) {
        Path path = Paths.get("example.txt");

        try {
            // 检查文件是否存在
            boolean exists = Files.exists(path);

            // 创建一个文件
            Files.createFile(path);

            // 读取文件的所有字节
            byte[] allBytes = Files.readAllBytes(path);

            // 将字节写入文件
            Files.write(path, allBytes);

            // 删除文件
            Files.delete(path);

            // 移动文件到另一个路径
            Path targetPath = Paths.get("destination.txt");
            Files.move(path, targetPath, CopyOption.REPLACE_EXISTING);

            // 读取文件的所有行
            Charset charset = Charset.forName("UTF-8");
            Files.write(path, Files.readAllLines(path, charset), charset);

            // 打开目录并过滤文件
            Path dirPath = Paths.get(".");
            try (DirectoryStream<Path> stream = Files.newDirectoryStream(dirPath, new DirectoryStream.Filter<Path>() {
                @Override
                public boolean accept(Path entry) throws IOException {
                    return Files.isDirectory(entry);
                }
            })) {
                for (Path entry : stream) {
                    System.out.println(entry.getFileName());
                }
            }
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}

总结

  • Files类提供了大量静态方法,用于对文件和目录进行各种操作。
  • 这些方法支持函数式编程,允许使用Lambda表达式和方法引用作为参数。
  • 使用Files类可以避免使用传统的IO类(如FileInputStreamFileOutputStream),并且代码通常更简洁、更易于理解。

十八、Java容器都有哪些?

在Java中,ListSetMap都是继承自java.util.Collection接口的集合类型,但它们在数据结构、性能特性和使用场景上有所不同:

  1. List接口

    • List是一个有序的集合,可以包含重复的元素。
    • 它提供了通过索引位置来访问元素的能力,即每个元素都有一个顺序位置。
    • 常见的实现类有ArrayListLinkedListVector
    • ArrayList提供快速的随机访问,适合频繁读取的场景;LinkedList提供快速的插入和删除操作,适合频繁修改的场景。
  2. Set接口

    • Set是一个不允许包含重复元素的集合。
    • 它也是无序的,但不同实现可能会有不同的迭代顺序(例如HashSet是无序的,而TreeSet可以保持自然排序或根据提供的Comparator进行排序)。
    • 常见的实现类有HashSetLinkedHashSetTreeSet
    • HashSet提供快速查找和添加操作,但迭代顺序不保证;LinkedHashSet保留了元素的插入顺序;TreeSet可以保持元素的排序。
  3. Map接口

    • Map是一个键值对的集合,每个键只能映射到一个值,键是唯一的。
    • 它不是用于存储单个元素的,而是存储键值对,并且键不能重复。
    • 常见的实现类有HashMapLinkedHashMapTreeMapHashtable
    • HashMap提供最快的查找速度,但键和值都不允许为null,且无序;LinkedHashMap保留了插入顺序;TreeMap可以保持键的排序。

性能特性

  • ArrayList适合随机访问,但不适合频繁的插入和删除操作。
  • LinkedList适合频繁的插入和删除操作,但不适合随机访问。
  • HashSetHashMap提供最快的查找和添加操作,但HashSet不保证迭代顺序,而HashMap不保证键和值的顺序。
  • LinkedHashSetLinkedHashMap保留了元素的插入顺序。
  • TreeSetTreeMap保持了元素的自然排序或根据提供的Comparator进行排序。

使用场景

  • 当需要索引或顺序访问时,使用List
  • 当需要确保元素唯一性时,使用Set
  • 当需要存储键值对时,使用Map

示例代码

// List示例
List<String> list = new ArrayList<>();
list.add("Java");
list.add("Python");
String item = list.get(0); // 获取第一个元素

// Set示例
Set<String> set = new HashSet<>();
set.add("Java");
boolean contains = set.contains("Python"); // 检查元素是否存在

// Map示例
Map<String, String> map = new HashMap<>();
map.put("Java", "JVM");
String value = map.get("Java"); // 通过键获取值

总结

  • ListSetMap是Java集合框架中的三种基础集合类型,它们在数据结构、性能和使用场景上有所不同。
  • 选择合适的集合类型对于程序的性能和功能至关重要。
  • 16
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值