1. Overview
In this quick tutorial, weβre going to learn how to create a new File in Java β first using the Files and Path classes from NIO, then the Java File and FileOutputStream classes, Google Guava, and finally the Apache Commons IO library.
This article is part of the βJava β Back to Basicβ series here on Baeldung.
2. Setup
In the examples, weβll define a constant for the file name:
private final String FILE_NAME = "src/test/resources/fileToCreate.txt";
And weβll also add a clean-up step to make sure that the file doesnβt already exist before each test, and to delete it after each test runs:
@AfterEach
@BeforeEach
public void cleanUpFiles() {
File targetFile = new File(FILE_NAME);
targetFile.delete();
}
3. Using NIO Files.createFile()
Letβs start by using the Files.createFile() method from the Java NIO package:
@Test
public void givenUsingNio_whenCreatingFile_thenCorrect() throws IOException {
Path newFilePath = Paths.get(FILE_NAME);
Files.createFile(newFilePath);
}
As you can see the code is still very simple; weβre now using the new Path interface instead of the old File.
One thing to note here is that the new API makes good use of exceptions. If the file already exists, we no longer have to check a return code. Instead, weβll get a FileAlreadyExistsException:
java.nio.file.FileAlreadyExistsException: src/test/resources/fileToCreate.txt at sun.n.f.WindowsException.translateToIOException(WindowsException.java:81)
4. Using File.createNewFile()
Letβs now look at how we can do the same using the java.io.File class:
@Test
public void givenUsingFile_whenCreatingFile_thenCorrect() throws IOException {
File newFile = new File(FILE_NAME);
boolean success = newFile.createNewFile();
assertTrue(success);
}
Note that the file must not exist for this operation to succeed. If the file does exist, then the createNewFile() operation will return false.
5. Using FileOutputStream
Another way to create a new file is to use the java.io.FileOutputStream:
@Test
public void givenUsingFileOutputStream_whenCreatingFile_thenCorrect() throws IOException {
try(FileOutputStream fileOutputStream = new FileOutputStream(FILE_NAME)){
}
}
In this case, a new file is created when we instantiate the FileOutputStream object. If a file with a given name already exists, it will be overwritten. If, however, the existing file is a directory or a new file cannot be created for any reason, then weβll get a FileNotFoundException.
Additionally, note we used a try-with-resources statement β to be sure that a stream is properly closed.
6. Using Guava
The Guava solution for creating a new file is a quick one-liner as well:
@Test
public void givenUsingGuava_whenCreatingFile_thenCorrect() throws IOException {
com.google.common.io.Files.touch(new File(FILE_NAME));
}
7. Using Apache Commons IO
The Apache Commons library provides the FileUtils.touch() method which implements the same behavior as the βtouchβ utility in Linux.
Therefore it creates a new empty file or even a file and the full path to it in a file system:
@Test
public void givenUsingCommonsIo_whenCreatingFile_thenCorrect() throws IOException {
FileUtils.touch(new File(FILE_NAME));
}
Note that this behaves slightly differently than the previous examples: if the file already exists, the operation doesnβt fail, it simply doesnβt do anything.
And there we have it β 4 quick ways to create a new file in Java.
8. Conclusion
In this article, we looked at different solutions for creating a file in Java. We used classes that are part of the JDK and external libraries.
