File.mkdir or mkdirs return false - Reason?

Why file.mkdir is returning false?

Google indicates that there could be several reasons (e.g. security, permissions, pathname, etc).

My questions:

  1. How to find the exact reason of returning false?
  2. If security/permissions is a reason, then why is SecurityException not thrown?

Answers


If security/permissions is a reason, then why is SecurityException NOT thrown (which is mentioned in javadoc)?

A SecurityException is thrown when you don't have JVM-level permission to do something, not OS-level

Is there a way to find the exact reason why of returning false?

No, AFAIK. The only way to know would be to check the permissions on the directory yourself, make sure it doesn't exist before calling them, check if the parent directory exists, etc.

However, if you're using Java 7 or higher, you can use NIO instead to create the directory. Specifically, Files.createDirectory:

File dir = new File("mydir");
Files.createDirectory(dir.toPath());

If you want to use NIO entirely without using java.io.File, you can use Paths.get to create a Path instead:

Path dir = Paths.get("mydir");
Files.createDirectory(dir);

In both cases, if the directory can't be created, it will throw an IOException with an exact reason for why the operation failed.

This is true for most of the methods in Files, and so using it is recommended over using the methods in the File class.


mkdir and mkdirs return false if the directory already exists, so that might be one reason for the failure.

If you are using Java 7, you can use the Files class. It throws an IOException on error with pretty good descriptions.

Files.createDirectory(file.toPath());

  1. No, there's no way to find the exact reason mkdirs() returns false, at least not from within Java, as it would probably be OS dependent.

  2. A SecurityException is thrown if there is a security violation in the SecurityManager's checkRead() and checkWrite() methods. The exception isn't thrown if there is an OS permissions issue.


Additionally, note that if you call File.mkdir(), and the parent directory doesn't exist, mkdir() will return false. However, calling File.mkdirs() will create the non-existent parent directories.


Here's something specific to Windows: In my case, the file.mkdir() method was failing with NoSuchFileException because I was trying to create a nested directory structure directly (e.g. results\results_ddMMyyyy without first creating the results directory) on Windows.

However, the exact same code worked fine on my Mac, i.e. no such exception was thrown on Mac and the intermediate results directory was created implicitly by the file.mkdir() method.

Hope this helps someone in future.


Need Your Help

android - accessing test application assets

android xml unit-testing assets suite

I've an XML file in the assets directory of my test application. I want to access this file from my suite method of the test class.

How to use dynamic SQL query in MyBatis with annotation(how to use selectProvider)?

orm annotations mapping mybatis

I am trying to avoid having an additional xml to define the mapper in mybatis3. Annotation fits right in.