TrueVFS 在卸载后无法删除文件并抛出以下异常。
java.nio.file.DirectoryNotEmptyException: tar:file:/D:/tmp/0554de32-5a95-4b58-a05d-d12effa68abc.tar!/ at net.java.truevfs.kernel.impl.ArchiveFileSystem.unlink(ArchiveFileSystem.scala:326) at net.java.truevfs.kernel.impl.BasicArchiveController.unlink(BasicArchiveController.scala:222) at net.java.truevfs.kernel.impl.DefaultManager$BackController.net$java$truevfs$kernel$impl$CacheController$$super$unlink(DefaultManager.scala:39) at net.java.truevfs.kernel.impl.CacheController$class.unlink(CacheController.scala:105) at net.java.truevfs.kernel.impl.DefaultManager$BackController.net$java$truevfs$kernel$impl$SyncController$$super$unlink(DefaultManager.scala:39) at net.java.truevfs.kernel.impl.SyncController$$anonfun$unlink$1.apply$mcV$sp(SyncController.scala:100) at net.java.truevfs.kernel.impl.SyncController$$anonfun$unlink$1.apply(SyncController.scala:98) at net.java.truevfs.kernel.impl.SyncController$$anonfun$unlink$1.apply(SyncController.scala:98) at net.java.truevfs.kernel.impl.SyncController$class.net$java$truevfs$kernel$impl$SyncController$$apply(SyncController.scala:119) at net.java.truevfs.kernel.impl.SyncController$class.unlink(SyncController.scala:98) at net.java.truevfs.kernel.impl.DefaultManager$BackController.net$java$truevfs$kernel$impl$LockController$$super$unlink(DefaultManager.scala:39) at net.java.truevfs.kernel.impl.LockController$$anonfun$unlink$1.apply$mcV$sp(LockController.scala:92) at net.java.truevfs.kernel.impl.LockController$$anonfun$unlink$1.apply(LockController.scala:92) at net.java.truevfs.kernel.impl.LockController$$anonfun$unlink$1.apply(LockController.scala:92) at net.java.truevfs.kernel.impl.LockingStrategy.apply(LockingStrategy.scala:84) at net.java.truevfs.kernel.impl.LockController$class.unlink(LockController.scala:92) at net.java.truevfs.kernel.impl.DefaultManager$BackController.unlink(DefaultManager.scala:39) at net.java.truevfs.kernel.impl.ArchiveControllerAdapter.unlink(ArchiveControllerAdapter.scala:35) at net.java.truevfs.kernel.spec.FsDecoratingController.unlink(FsDecoratingController.java:111) at net.java.truevfs.kernel.impl.FalsePositiveArchiveController$$anonfun$1.apply(FalsePositiveArchiveController.scala:132) at net.java.truevfs.kernel.impl.FalsePositiveArchiveController$$anonfun$1.apply(FalsePositiveArchiveController.scala:131) at net.java.truevfs.kernel.impl.FalsePositiveArchiveController$TryChild$.apply(FalsePositiveArchiveController.scala:195) at net.java.truevfs.kernel.impl.FalsePositiveArchiveController.unlink(FalsePositiveArchiveController.scala:143) at net.java.truevfs.access.TFile.rm(TFile.java:2216) at net.java.truevfs.access.TFile.rm(TFile.java:2195
tar 文件已成功创建,因此没有问题。
这就是我正在做的事情。
配置真正的 VFS
TConfig 配置 = TConfig.current(); config.setArchiveDetector(new TArchiveDetector("tar", new TarDriver()));
创建焦油
卸载焦油
TVFS.umount(tarFile);
转换成字节并发送。
删除文件
tarFile.rm()
我还尝试了 tarFile.rm_r() 和普通的 java.io.File.delete()。但他们都没有工作。
有人可以告诉我出了什么问题吗?提前致谢。