java.io.File clase contiene cuatro variables de separador estáticas. Aquí aprenderemos sobre ellas y cuándo usarlas.
- File.separator: Carácter de separación de nombres predeterminado dependiente de la plataforma, representado como cadena. Para Windows, es ‘\’, y para Unix, es ‘/’.
- File.separatorChar: Igual que separator, pero es un carácter.
- File.pathSeparator: Variable dependiente de la plataforma para el separador de ruta. Por ejemplo, en sistemas Unix, la lista de variables de ruta como PATH o CLASSPATH está separada por ‘:’ y en sistemas Windows por ‘;’.
- File.pathSeparatorChar: Igual que pathSeparator, pero es un carácter.
Separador de archivos de Java
Nótese que todas estas son variables finales y dependientes del sistema. Aquí está el programa en Java para imprimir estas variables de separación.
package com.journaldev.files;
import java.io.File;
public class FileSeparator {
public static void main(String[] args) {
System.out.println("File.separator = "+File.separator);
System.out.println("File.separatorChar = "+File.separatorChar);
System.out.println("File.pathSeparator = "+File.pathSeparator);
System.out.println("File.pathSeparatorChar = "+File.pathSeparatorChar);
}
}
Salida del programa anterior en el sistema Unix:
File.separator = /
File.separatorChar = /
File.pathSeparator = :
File.pathSeparatorChar = :
Salida del programa en el sistema Windows:
File.separator = \
File.separatorChar = \
File.pathSeparator = ;
File.pathSeparatorChar = ;
Para hacer nuestro programa independiente de la plataforma, siempre deberíamos usar estos separadores para crear la ruta de archivo o leer cualquier variable de sistema como PATH, CLASSPATH. Aquí hay un fragmento de código que muestra cómo usar los separadores correctamente.
//no hay independencia de plataforma, bueno para sistemas Unix
File fileUnsafe = new File("tmp/abc.txt");
//independiente de plataforma y seguro para usar en sistemas Unix y Windows
File fileSafe = new File("tmp"+File.separator+"abc.txt");
Eso es todo para los separadores de archivos, aprenderemos más sobre java io en futuras publicaciones.