热门标签 | HotTags
当前位置:  开发笔记 > 运维 > 正文

File的API和常用方法详解_动力节点Java学院整理

这篇文章主要为大家详细介绍了File的API和常用方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

File 介绍

File 是“文件”和“目录路径名”的抽象表示形式。
File 直接继承于Object,实现了Serializable接口和Comparable接口。实现Serializable接口,意味着File对象支持序列化操作。而实现Comparable接口,意味着File对象之间可以比较大小;File能直接被存储在有序集合(如TreeSet、TreeMap中)。

File 函数列表

// 静态成员
public static final String  pathSeparator  // 路径分割符":"
public static final char  pathSeparatorChar // 路径分割符':'
public static final String  separator   // 分隔符"/"
public static final char  separatorChar  // 分隔符'/'

// 构造函数
File(File dir, String name)
File(String path)
File(String dirPath, String name)
File(URI uri)

// 成员函数
boolean canExecute() // 测试应用程序是否可以执行此抽象路径名表示的文件。
boolean canRead()  // 测试应用程序是否可以读取此抽象路径名表示的文件。
boolean canWrite()  // 测试应用程序是否可以修改此抽象路径名表示的文件。
int compareTo(File pathname) // 按字母顺序比较两个抽象路径名。
boolean createNewFile()   // 当且仅当不存在具有此抽象路径名指定名称的文件时,不可分地创建一个新的空文件。
static File createTempFile(String prefix, String suffix) // 在默认临时文件目录中创建一个空文件,使用给定前缀和后缀生成其名称。
static File createTempFile(String prefix, String suffix, File directory) // 在指定目录中创建一个新的空文件,使用给定的前缀和后缀字符串生成其名称。
boolean delete()    // 删除此抽象路径名表示的文件或目录。
void deleteOnExit()  // 在虚拟机终止时,请求删除此抽象路径名表示的文件或目录。
boolean equals(Object obj) // 测试此抽象路径名与给定对象是否相等。
boolean exists()    // 测试此抽象路径名表示的文件或目录是否存在。
File getAbsoluteFile() // 返回此抽象路径名的绝对路径名形式。
String getAbsolutePath() // 返回此抽象路径名的绝对路径名字符串。
File getCanonicalFile() // 返回此抽象路径名的规范形式。
String getCanonicalPath() // 返回此抽象路径名的规范路径名字符串。
long getFreeSpace()  // 返回此抽象路径名指定的分区中未分配的字节数。
String getName()   // 返回由此抽象路径名表示的文件或目录的名称。
String getParent()   // 返回此抽象路径名父目录的路径名字符串;如果此路径名没有指定父目录,则返回 null。
File getParentFile()  // 返回此抽象路径名父目录的抽象路径名;如果此路径名没有指定父目录,则返回 null。
String getPath()   // 将此抽象路径名转换为一个路径名字符串。
long getTotalSpace()  // 返回此抽象路径名指定的分区大小。
long getUsableSpace()  // 返回此抽象路径名指定的分区上可用于此虚拟机的字节数。
int hashCode()    // 计算此抽象路径名的哈希码。
boolean isAbsolute()   // 测试此抽象路径名是否为绝对路径名。
boolean isDirectory()  // 测试此抽象路径名表示的文件是否是一个目录。
boolean isFile()    // 测试此抽象路径名表示的文件是否是一个标准文件。
boolean isHidden()   // 测试此抽象路径名指定的文件是否是一个隐藏文件。
long lastModified()  // 返回此抽象路径名表示的文件最后一次被修改的时间。
long length()    // 返回由此抽象路径名表示的文件的长度。
String[] list()   // 返回一个字符串数组,这些字符串指定此抽象路径名表示的目录中的文件和目录。
String[] list(FilenameFilter filter) // 返回一个字符串数组,这些字符串指定此抽象路径名表示的目录中满足指定过滤器的文件和目录。
File[] listFiles()      // 返回一个抽象路径名数组,这些路径名表示此抽象路径名表示的目录中的文件。
File[] listFiles(FileFilter filter)  // 返回抽象路径名数组,这些路径名表示此抽象路径名表示的目录中满足指定过滤器的文件和目录。
File[] listFiles(FilenameFilter filter) // 返回抽象路径名数组,这些路径名表示此抽象路径名表示的目录中满足指定过滤器的文件和目录。
static File[] listRoots() // 列出可用的文件系统根。
boolean mkdir()  // 创建此抽象路径名指定的目录。
boolean mkdirs() // 创建此抽象路径名指定的目录,包括所有必需但不存在的父目录。
boolean renameTo(File dest) // 重新命名此抽象路径名表示的文件。
boolean setExecutable(boolean executable) // 设置此抽象路径名所有者执行权限的一个便捷方法。
boolean setExecutable(boolean executable, boolean ownerOnly) // 设置此抽象路径名的所有者或所有用户的执行权限。
boolean setLastModified(long time)  // 设置此抽象路径名指定的文件或目录的最后一次修改时间。
boolean setReadable(boolean readable) // 设置此抽象路径名所有者读权限的一个便捷方法。
boolean setReadable(boolean readable, boolean ownerOnly) // 设置此抽象路径名的所有者或所有用户的读权限。
boolean setReadOnly()     // 标记此抽象路径名指定的文件或目录,从而只能对其进行读操作。
boolean setWritable(boolean writable) // 设置此抽象路径名所有者写权限的一个便捷方法。
boolean setWritable(boolean writable, boolean ownerOnly) // 设置此抽象路径名的所有者或所有用户的写权限。
String toString() // 返回此抽象路径名的路径名字符串。
URI toURI() // 构造一个表示此抽象路径名的 file: URI。
URL toURL() // 已过时。 此方法不会自动转义 URL 中的非法字符。建议新的代码使用以下方式将抽象路径名转换为 URL:首先通过 toURI 方法将其转换为 URI,然后通过 URI.toURL 方法将 URI 装换为 URL。

1. 新建目录的常用方法

方法1:根据相对路径新建目录。

示例代码如下(在当前路径下新建目录“dir”):

File dir = new File("dir");
dir.mkdir();

方法2:根据绝对路径新建目录。

示例代码如下(新建目录“/home/skywang/dir”):

File dir = new File("/home/skywang/dir");
dir.mkdirs();

说明:上面是在linux系统下新建目录“/home/skywang/dir”的源码。在windows下面,若要新建目录“D:/dir”,源码如下:

File dir = new File("D:/dir");
dir.mkdir();

方法3:

URI uri = new URI("file:/home/skywang/dir"); 
File dir = new File(uri);
sub.mkdir();

说明: 和“方法2”类似,只不过“方法2”中传入的是完整路径,而“方法3”中传入的是完整路径对应URI。

2. 新建子目录的几种常用方法

例如,我们想要在当前目录的子目录“dir”下,再新建一个子目录。有一下几种方法:

方法1

File sub1 = new File("dir", "sub1");
sub1.mkdir();

说明:上面的方法作用是,在当前目录下 "dir/sub1"。它能正常运行的前提是“sub1”的父目录“dir”已经存在!

方法2

File sub2 = new File(dir, "sub2");
sub2.mkdir();

说明:上面的方法作用是,在当前目录下 "dir/sub2"。它能正常运行的前提是“sub2”的父目录“dir”已经存在!

方法3

File sub3 = new File("dir/sub3");
sub3.mkdirs();

说明:上面的方法作用是,在当前目录下 "dir/sub3"。它不需要dir已经存在,也能正常运行;若“sub3”的父母路不存在,mkdirs()方法会自动创建父目录。

方法4

File sub4 = new File("/home/skywang/dir/sub4");
sub4.mkdirs();

说明:上面的方法作用是,新建目录"/home/skywang/dir/sub3"。它不需要dir已经存在,也能正常运行;若“sub4”的父母路不存在,mkdirs()方法会自动创建父目录。

方法5

URI uri = new URI("file:/home/skywang/dir/sub5"); 
File sub5 = new File(uri);
sub5.mkdirs();

说明: 和“方法4”类似,只不过“方法4”中传入的是完整路径,而“方法5”中传入的是完整路径对应URI。

 3. 新建文件的几种常用方法

例如,我们想要在当前目录的子目录“dir”下,新建一个文件。有一下几种方法

方法1

try {
 File dir = new File("dir"); // 获取目录“dir”对应的File对象
 File file1 = new File(dir, "file1.txt");
 file1.createNewFile();
} catch (IOException e) {
 e.printStackTrace();
}

说明:上面代码作用是,在“dir”目录(相对路径)下新建文件“file1.txt”。

方法2

try {
 File file2 = new File("dir", "file2.txt");
 file2.createNewFile();
} catch (IOException e) {
 e.printStackTrace();
}

说明:上面代码作用是,在“dir”目录(相对路径)下新建文件“file2.txt”。

方法3

try {
 File file3 = new File("/home/skywang/dir/file3.txt");
 file3.createNewFile();
} catch (IOException e) {
 e.printStackTrace();
}

说明:上面代码作用是,下新建文件“/home/skywang/dir/file3.txt”(绝对路径)。这是在linux下根据绝对路径的方法,在windows下可以通过以下代码新建文件"D:/dir/file4.txt"。

try {
 File file3 = new File("D:/dir/file4.txt");
 file3.createNewFile();
} catch (IOException e) {
 e.printStackTrace();
}

方法4

try {
 URI uri = new URI("file:/home/skywang/dir/file4.txt"); 
 File file4 = new File(uri);
 file4.createNewFile();
} catch (IOException e) {
 e.printStackTrace();
}

说明:

和“方法3”类似,只不过“方法3”中传入的是完整路径,而“方法4”中传入的是完整路径对应URI。

File API使用示例

关于File中API的详细用法,参考示例代码(FileTest.java):

import java.io.File;
import java.io.IOException;
import java.net.URI;
import java.util.Calendar;
import java.text.SimpleDateFormat;

public class FileTest {

 public static void main(String[] args) {
  testFileStaticFields() ;
 testFileDirAPIS() ;
 }

 public static void testFileStaticFields() {
  // 打印 路径分隔符":"
  System.out.printf("File.pathSeparator=\"%s\"\n", File.pathSeparator);
  // 打印 路径分隔符':'
  System.out.printf("File.pathSeparatorChar=\"%c\"\n", File.pathSeparatorChar);
  // 打印 分隔符"/"
  System.out.printf("File.separator=\"%s\"\n", File.separator);
  // 打印 分隔符'/'
  System.out.printf("File.separatorChar=\"%c\"\n", File.separatorChar);
 }

 public static void testFileDirAPIS() {
  try {
  // 新建目录 "dir"
  File dir = new File("dir");
  dir.mkdir();

  // 方法1:新建目录 "dir/sub1"。父目录“dir”必须已经存在!
  File sub1 = new File("dir", "sub1");
  sub1.mkdir();
  // 方法2:新建目录 "dir/sub2"。父目录“dir”必须已经存在!
  File sub2 = new File(dir, "sub2");
  sub2.mkdir();
  // 方法3:新建目录 "dir/sub3"。mkdirs()会自动创建不存在的父目录。
  File sub3 = new File("dir/sub3");
  sub3.mkdirs();
  // 方法4:新建目录 "dir/sub4"。根据“绝对路径”创建,前面3个方法都是根据“相对路径”创建。
  String dirPath = dir.getAbsolutePath(); // 获取“dir”的绝对路径
  String sub4AbsPath = dirPath + File.separator + "sub4"; // File.separator是分隔符"/"
  File sub4 = new File(sub4AbsPath);
  sub4.mkdirs();
  // 方法5:新建目录 "dir/sub5"。根据uri
  String uri_sub5_path = "file:"+ dirPath + File.separator + "sub5";
  URI uri_sub5 = new URI(uri_sub5_path); 
  File sub5 = new File(uri_sub5);
  sub5.mkdirs();

  // 方法1:新建文件 "dir/l1_normal.txt"
  File l1_normal = new File(dir, "l1_normal.txt");
  l1_normal.createNewFile();
  // 方法2:新建文件 "dir/.l1_hide.txt"。
  File l1_hide = new File("dir", ".l1_hide.txt"); // 在linux中, "."开头的文件是隐藏文件。
  l1_hide.createNewFile();
  // 方法3:新建文件 "dir/l1_abs.txt"。
  String dirAbsPah = dir.getAbsolutePath(); // 获取dir的绝对路径
  String l1_abs_path = dirAbsPah+File.separator+"l1_abs.txt";
  File l1_abs = new File(l1_abs_path);
  l1_abs.createNewFile();
  //System.out.printf("l1_abs_path=%s\n", l1_abs_path);
  //System.out.printf("l1_abs path=%s\n", l1_abs.getAbsolutePath());
  // 方法4:新建文件 "dir/l1_uri.txt"。根据URI新建文件
  String uri_path = "file:"+ dirAbsPah + File.separator + "l1_uri.txt";
  URI uri_l1 = new URI(uri_path); 
  //System.out.printf("uri_l1=%s\n", l1_abs.getAbsolutePath());
  File l1_uri = new File(uri_l1); 
  l1_uri.createNewFile();

  // 新建文件 "dir/sub/s1_normal"
  File s1_normal = new File(sub1, "s1_normal.txt");
  s1_normal.createNewFile();

  System.out.printf("%30s = %s\n", "s1_normal.exists()", s1_normal.exists());
  System.out.printf("%30s = %s\n", "s1_normal.getName()", s1_normal.getName());
  System.out.printf("%30s = %s\n", "s1_normal.getParent()", s1_normal.getParent());
  System.out.printf("%30s = %s\n", "s1_normal.getPath()", s1_normal.getPath());
  System.out.printf("%30s = %s\n", "s1_normal.getAbsolutePath()", s1_normal.getAbsolutePath());
  System.out.printf("%30s = %s\n", "s1_normal.getCanonicalPath()", s1_normal.getCanonicalPath());
  System.out.printf("%30s = %s is \"%s\"\n", "s1_normal.lastModified()", s1_normal.lastModified(), getModifyTime(s1_normal.lastModified()));
  System.out.printf("%30s = %s\n", "s1_normal.toURI()", s1_normal.toURI());


  // 列出“dir”目录下的“文件”和“文件夹”。
  // 注意:dir.listFiles()只会遍历目录dir,而不会遍历dir的子目录!
  System.out.println("---- list files and folders ----");
  File[] fs = dir.listFiles();
  for (File f:fs) {
   String fname = f.getName();
   String absStr = f.isAbsolute() ? "[Absolute]" : "";
   String hidStr = f.isHidden() ? "[Hidden]" : "";
   String dirStr = f.isDirectory() ? "[Directory]" : "";
   String fileStr = f.isFile() ? "[File]" : "";

   System.out.printf("%-30s %s%s%s%s\n", fname, fileStr, dirStr, absStr, hidStr);
  }

  } catch (Exception e) {
   e.printStackTrace();
  }
 }

 private static String getModifyTime(long millis) {
  // 获取Calendar对象
  Calendar cal = Calendar.getInstance();
  // 设置时间为 millis
  cal.setTimeInMillis(millis);
  // 获取格式化对象,它会按照"yyyy-MM-dd HH:mm:ss"格式化日期
  SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
  //System.out.printf("TIME %s\n", str);
  return sdf.format(cal.getTime()); 
 }

}

运行结果(在ubuntu 12.04系统下的运行结果,而不是windows!):

File.pathSeparator=":"
File.pathSeparatorChar=":"
File.separator="/"
File.separatorChar="/"
            s1_normal.exists() = true
           s1_normal.getName() = s1_normal.txt
         s1_normal.getParent() = dir/sub1
           s1_normal.getPath() = dir/sub1/s1_normal.txt
   s1_normal.getAbsolutePath() = /home/skywang/wind_talker/workout/java/skywang/io/io/src/file/dir/sub1/s1_normal.txt
  s1_normal.getCanonicalPath() = /home/skywang/wind_talker/workout/java/skywang/io/io/src/file/dir/sub1/s1_normal.txt
      s1_normal.lastModified() = 1381730064000 is "2013-10-14 13:54:24"
             s1_normal.toURI() = file:/home/skywang/wind_talker/workout/java/skywang/io/io/src/file/dir/sub1/s1_normal.txt
---- list files and folders ----
l1_uri.txt                      [File]
sub1                            [Directory]
l1_abs.txt                      [File]
sub5                            [Directory]
sub4                            [Directory]
.l1_hide.txt                    [File][Hidden]
sub3                            [Directory]
sub2                            [Directory]
l1_normal.txt                   [File]

结果说明:运行程序,会在源文件所在的目录新建目录"dir"及其子目录和子文件。如下图:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


推荐阅读
  • 本文探讨了Linux环境下线程私有数据(Thread-Specific Data, TSD)的概念及其重要性,介绍了如何通过TSD技术避免多线程间全局变量冲突的问题,并提供了具体的实现方法和示例代码。 ... [详细]
  • 本文概述了在GNU/Linux系统中,动态库在链接和运行阶段的搜索路径及其指定方法,包括通过编译时参数、环境变量及系统配置文件等方式来控制动态库的查找路径。 ... [详细]
  • Node.js模块化的优势及实践
    本文探讨Node.js模块化的重要性和具体实现方式,包括其带来的代码复用性增强、可维护性提升、以及如何有效避免命名冲突等问题。 ... [详细]
  • 本文介绍了Linux内核中TCP的三种接收队列:Prequeue、sk_receive_queue和Backlog。这些队列在数据包处理过程中扮演着重要角色,帮助提高系统性能和效率。 ... [详细]
  • 在Linux系统中使用EncFS实现文件夹加密
    为了保护个人隐私或敏感数据不被未经授权的访问,可以通过加密技术来增强安全性。本文介绍如何在Linux系统上使用EncFS工具创建和管理加密文件夹,以确保即使在系统登录状态下,特定文件夹中的数据也保持加密状态。 ... [详细]
  • Linux内核中的内存反碎片技术解析
    本文深入探讨了Linux内核中实现的内存反碎片技术,包括其历史发展、关键概念如虚拟可移动区域以及具体的内存碎片整理策略。旨在为开发者提供全面的技术理解。 ... [详细]
  • 如何高效学习鸿蒙操作系统:开发者指南
    本文探讨了开发者如何更有效地学习鸿蒙操作系统,提供了来自行业专家的建议,包括系统化学习方法、职业规划建议以及具体的开发技巧。 ... [详细]
  • Java中提取字符串的最后一部分
    本文介绍了如何使用Java中的substring()和split()方法来提取字符串的最后一部分,特别是在处理包含特殊字符的路径时的方法与技巧。 ... [详细]
  • 实现Win10与Linux服务器的SSH无密码登录
    本文介绍了如何在Windows 10环境下使用Git工具,通过配置SSH密钥对,实现与Linux服务器的无密码登录。主要步骤包括生成本地公钥、上传至服务器以及配置服务器端的信任关系。 ... [详细]
  • 汇总了2023年7月7日最新的网络安全新闻和技术更新,包括最新的漏洞披露、工具发布及安全事件。 ... [详细]
  • 在使用 PyInstaller 将 Python 应用程序打包成独立的可执行文件时,若项目中包含动态加载的库或插件,需要正确配置 --hidden-import 和 --add-binary 参数,以确保所有依赖项均能被正确识别和打包。 ... [详细]
  • 本文探讨了服务器系统架构的性能评估方法,包括性能评估的目的、步骤以及如何选择合适的度量标准。文章还介绍了几种常用的基准测试程序及其应用,并详细说明了Web服务器性能评估的关键指标与测试方法。 ... [详细]
  • WebBenchmark:强大的Web API性能测试工具
    本文介绍了一款名为WebBenchmark的Web API性能测试工具,该工具不仅支持HTTP和HTTPS服务的测试,还提供了丰富的功能来帮助开发者进行高效的性能评估。 ... [详细]
  • 一文详解Linux
    Linuxnetfilter与VRF实验环境如下图所示:配置如下:#!binbashsudoipnetnsaddns1sudoiplinkaddns1veth1typevethpe ... [详细]
  • 本文详细介绍了如何在 Ubuntu 14.04 系统上搭建仅使用 CPU 的 Caffe 深度学习框架,包括环境准备、依赖安装及编译过程。 ... [详细]
author-avatar
月曳柳覀梢
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有