在Python
我可以加入两个路径os.path.join
:
os.path.join("foo", "bar") # => "foo/bar"
我想才达到在Java中一样,不用担心,如果OS
是Unix
,Solaris
或Windows
:
public static void main(String[] args) {
Path currentRelativePath = Paths.get("");
String current_dir = currentRelativePath.toAbsolutePath().toString();
String filename = "data/foo.txt";
Path filepath = currentRelativePath.resolve(filename);
// "data/foo.txt"
System.out.println(filepath);
}
我期待那Path.resolve( )
会加入我的当前目录/home/user/test
与data/foo.txt
制作/home/user/test/data/foo.txt
。我怎么了?
即使使用该方法获得当前目录的原始解决方案也是如此empty String
。但是建议将该user.dir
属性用于当前目录和user.home
主目录。
Path currentPath = Paths.get(System.getProperty("user.dir"));
Path filePath = Paths.get(currentPath.toString(), "data", "foo.txt");
System.out.println(filePath.toString());
输出:
/Users/user/coding/data/foo.txt
从Java
Path类文档中:
如果Path仅由一个name元素组成,则将其视为空路径
empty
。使用empty path is equivalent to accessing the default directory
的文件系统访问文件。
为什么Paths.get("").toAbsolutePath()
起作用
当将空字符串传递给时Paths.get("")
,返回的Path
对象包含空路径。但是,当我们调用时Path.toAbsolutePath()
,它将检查路径长度是否大于零,否则它将使用user.dir
系统属性并返回当前路径。
这是Unix文件系统实现的代码:UnixPath.toAbsolutePath()
基本上Path
,一旦您解析了当前目录路径,就需要再次创建该实例。
我也建议使用File.separatorChar
平台无关的代码。
Path currentRelativePath = Paths.get("");
Path currentDir = currentRelativePath.toAbsolutePath(); // <-- Get the Path and use resolve on it.
String filename = "data" + File.separatorChar + "foo.txt";
Path filepath = currentDir.resolve(filename);
// "data/foo.txt"
System.out.println(filepath);
输出:
/Users/user/coding/data/foo.txt
本文向大家介绍Java连接Vmware中的redis,包括了Java连接Vmware中的redis的使用技巧和注意事项,需要的朋友参考一下 本文使用的vmware 11,安装的系统是centos6.7,redis版本是3..0.2 。如何安装请参考上一篇文章《Linux下安装Redis并设置相关服务》。 安装完redis以后,我们是不是要迫不及待的想使用一下呢。那么我们要在程序中
这是类的构造函数之一。新对象在数据库中创建新记录。当我在源代码中“手工”创建这个对象时,一切都很好。但是当我将创建声明放入按钮的actionlistener中时,编译器返回sql异常。 我得到的例外是
我正在研究MQTT协议。我配置了它的服务器,并使用端口1883上的Mosquito库用java进行了通信。现在,我想让这种通信更加安全。据我所知,8883端口是为其基于tls的安全通信保留的。它需要X.509证书。为此,我找到了以下教程。 http://www.embedded101.com/Blogs/PaoloPatierno/entryid/366/mqtt-over-ssl-tls-wit
问题内容: 我有一个ResultSet方法,该方法将最终关闭连接: 但是我得到了错误: 编辑整个ErrorTrace 我在做什么不对? 问题答案: 您将返回一个a 以便将来使用,但是在使用它之后,您将关闭连接,因此由于资源已关闭,因此您无法检索数据。请注意,即使您在或代码块中返回了某些内容,也始终会调用它, 详细来说,这就是问题所在: 打开连接 准备一份声明 获取结果集 返回结果集 关闭连接(可能
例子 $ gcc -print-file-name=libc.a /usr/lib/gcc/x86_64-linux-gnu/4.6/../../../x86_64-linux-gnu/libc.a 技巧 如上所示,使用-print-file-name选项就可以显示出gcc究竟会连接哪个libc库了。 详情参见 gcc手册
问题内容: 我正在加密服务器和客户端之间的TCP连接。在研究和测试过程中,我倾向于使用秘密密钥加密。我的问题是我找不到有关如何实现此功能的任何教程。我发现的教程围绕一次HTTP请求进行,我只需要一个SSL套接字。 我到目前为止编写的代码如下。我几乎可以肯定它需要扩展,我只是不知道该怎么做。任何帮助表示赞赏。 接受客户端连接的服务器代码 我只是不知道如何实际进行握手。 参考:http : //doc