使用文件有什么区别。分隔符和正常的/在Java路径字符串?

与双反斜杠相比,平台独立性似乎不是原因,因为这两个版本都可以在Windows和Unix下运行。

public class SlashTest {
    @Test
    public void slash() throws Exception {
        File file = new File("src/trials/SlashTest.java");
        assertThat(file.exists(), is(true));
    }

    @Test
    public void separator() throws Exception {
        File file = new File("src" + File.separator + "trials" + File.separator + "SlashTest.java");
        assertThat(file.exists(), is(true));
    }
}

换句话说,如果/可以在Unix和Windows上工作,为什么要使用File.separator?


操作系统比Unix和Windows多(可移植设备等),Java以其可移植性而闻名。最佳实践是使用它,这样JVM就可以确定哪个最适合该操作系统。


您使用File。分隔符,因为有一天你的程序可能会在一个遥远的地方开发的平台上运行,一个充满奇怪的事物和陌生的人的地方,在那里,马会哭,所有的电梯都是由奶牛操纵的。在这片土地上,人们传统上使用“:”字符作为文件分隔符,因此JVM服从他们的意愿。


使用处理文件的Java库,您可以在所有平台上安全地使用/(斜杠,而不是反斜杠)。库代码在内部处理将内容转换到特定于平台的路径。

您可能需要使用File。分隔符,但是,因为它最好向人们展示什么在他们的操作系统中是有意义的,而不是什么在Java中是有意义的。

更新:在五分钟的搜索中,我还没能找到“你总是可以使用斜杠”的行为文档。现在,我确信我已经看到了它的文档,但在没有找到官方参考的情况下(因为我的记忆不完美),我将坚持使用File。分离器,因为你知道那会有用。


便携性简单明了。


虽然使用File。分隔符来引用文件名是多余的(对于那些想象遥远的地方的人来说,我想象他们的JVM实现将用a:替换/,就像windows的JVM用\替换它一样)。

然而,有时您正在获取文件引用,而不是创建它,您需要解析它,为了能够做到这一点,您需要知道平台上的分隔符。文件。Separator帮助你做到这一点。


虽然进去的时候没有太大区别,但回来的时候就有了。

当然,你可以在新文件(字符串路径)中使用'/'或'\',但File. getpath()只会给你其中一个。


文件或目录的路径名使用主机系统的命名约定指定。但是,File类定义了与平台相关的常量,可用于以与平台无关的方式处理文件和目录名。

文件。分隔符定义在路径名中分隔目录和文件组件的字符或字符串。对于Unix、Windows和Macintosh,分隔符分别为'/'、'\'或':'。


如果你使用的是Java 7,签出Path.resolve()和Paths.get()。


“Java SE8 for Programmers”声称Java可以应付这两种情况。(第480页,最后一段)。 这个例子声称:

c:\Program Files\Java\jdk1.6.0_11\demo/jfc

会很好地解析。注意最后一个(unix风格的)分隔符。

这很俗气,而且可能容易出错,但这就是他们(Deitel和Deitel)所宣称的。

我认为人们的困惑,而不是Java,是足够的理由不使用这个(mis?)特性。


正如两位先生所描述的不同细节。

我想推荐使用Apache Commons io api,类FilenameUtils在处理程序中的文件时,可以在多个操作系统上部署。


迟到了。我使用的是Windows 10, JDK 1.8和Eclipse MARS 1。 我发现

.getResourceAsStream .getClassLoader getClass()()(“路径/ /资源”);

工作和

.getResourceAsStream .getClassLoader getClass()()(“路径”+ File.separator + " " + File.separator +“资源”);

不工作

.getResourceAsStream .getClassLoader getClass()()(“路径\ \资源”);

不管用。后两个是等价的。所以…我有很好的理由不使用File.separator。


使用文件。separator使Ubuntu生成的文件名称上有“\”而不是目录。也许我在如何创建文件(和目录)方面很懒惰,本可以避免它,无论如何,每次都使用“/”来避免名称上带有“\”的文件


好的,让我们检查一些代码。 <init>:

String p = uri.getPath();
if (p.equals(""))
    throw new IllegalArgumentException("URI path component is empty");

// Okay, now initialize
p = fs.fromURIPath(p);
if (File.separatorChar != '/')
p = p.replace('/', File.separatorChar);

然后读取fs/*(FileSystem)*/.fromURIPath() docs:

java.io.FileSystem 字符串的路径 如果需要,对给定的URI路径字符串进行后处理。这是用于 Win32,例如,将“/c:/foo”转换为“c:/foo”。路径字符串 仍然有斜杠分隔;File类中的代码将转换它们 在此方法返回之后。

这意味着filessystem . fromuripath()只在Windows中对URI路径进行后处理,因为在下一行中:

p = p.replace('/', File.separatorChar);

它将每个'/'替换为依赖于系统的seperatorChar,您可以始终确保'/'在每个操作系统中都是安全的。


如果您试图使用Linux分隔符从一些现成的路径(保存在数据库中,每个例子)创建一个文件,我应该怎么做?

也许只需要使用创建文件的路径:

new File("/shared/folder/file.jpg");

但是Windows使用不同的分隔符(\)。那么,是否可以将斜杠分隔符转换为平台无关的?如:

new File(convertPathToPlatformIndependent("/shared/folder"));

这个方法convertPathToPlatformIndependent可能会被“/”分割,并连接File.separator。

对我来说,这对于独立于平台的语言来说并不好(对吧?),而且Java已经支持在Windows或Linux上使用/。但是如果您使用的是路径,并且每次都需要记住这种转换,这将是一场噩梦,并且您将不会为应用程序在未来获得任何实际收益(可能在@Pointy所描述的宇宙中)。