Package org.apache.commons.io.comparator
Class SizeFileComparator
- java.lang.Object
-
- org.apache.commons.io.comparator.SizeFileComparator
-
- All Implemented Interfaces:
java.io.Serializable,java.util.Comparator<java.io.File>
public class SizeFileComparator extends java.lang.Object implements java.io.SerializableCompare the length/size of two files for order (seeFile.length()andFileUtils.sizeOfDirectory(File)).This comparator can be used to sort lists or arrays of files by their length/size.
Example of sorting a list of files using the
SIZE_COMPARATORsingleton instance:List<File> list = ... ((AbstractFileComparator) SizeFileComparator.SIZE_COMPARATOR).sort(list);Example of doing a reverse sort of an array of files using the
SIZE_REVERSEsingleton instance:File[] array = ... ((AbstractFileComparator) SizeFileComparator.SIZE_REVERSE).sort(array);N.B. Directories are treated as zero size unless
sumDirectoryContentsistrue.- Since:
- 1.4
- See Also:
- Serialized Form
-
-
Field Summary
Fields Modifier and Type Field Description static java.util.Comparator<java.io.File>SIZE_COMPARATORSize comparator instance - directories are treated as zero sizestatic java.util.Comparator<java.io.File>SIZE_REVERSEReverse size comparator instance - directories are treated as zero sizestatic java.util.Comparator<java.io.File>SIZE_SUMDIR_COMPARATORSize comparator instance which sums the size of a directory's contents usingFileUtils.sizeOfDirectory(File)static java.util.Comparator<java.io.File>SIZE_SUMDIR_REVERSEReverse size comparator instance which sums the size of a directory's contents usingFileUtils.sizeOfDirectory(File)
-
Constructor Summary
Constructors Constructor Description SizeFileComparator()Construct a file size comparator instance (directories treated as zero size).SizeFileComparator(boolean sumDirectoryContents)Construct a file size comparator instance specifying whether the size of the directory contents should be aggregated.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description intcompare(java.io.File file1, java.io.File file2)Compare the length of two files.java.io.File[]sort(java.io.File... files)Sort an array of files.java.util.List<java.io.File>sort(java.util.List<java.io.File> files)Sort a List of files.java.lang.StringtoString()String representation of this file comparator.
-
-
-
Field Detail
-
SIZE_COMPARATOR
public static final java.util.Comparator<java.io.File> SIZE_COMPARATOR
Size comparator instance - directories are treated as zero size
-
SIZE_REVERSE
public static final java.util.Comparator<java.io.File> SIZE_REVERSE
Reverse size comparator instance - directories are treated as zero size
-
SIZE_SUMDIR_COMPARATOR
public static final java.util.Comparator<java.io.File> SIZE_SUMDIR_COMPARATOR
Size comparator instance which sums the size of a directory's contents usingFileUtils.sizeOfDirectory(File)
-
SIZE_SUMDIR_REVERSE
public static final java.util.Comparator<java.io.File> SIZE_SUMDIR_REVERSE
Reverse size comparator instance which sums the size of a directory's contents usingFileUtils.sizeOfDirectory(File)
-
-
Constructor Detail
-
SizeFileComparator
public SizeFileComparator()
Construct a file size comparator instance (directories treated as zero size).
-
SizeFileComparator
public SizeFileComparator(boolean sumDirectoryContents)
Construct a file size comparator instance specifying whether the size of the directory contents should be aggregated.If the
sumDirectoryContentsistrueThe size of directories is calculated usingFileUtils.sizeOfDirectory(File).- Parameters:
sumDirectoryContents-trueif the sum of the directories' contents should be calculated, otherwisefalseif directories should be treated as size zero (seeFileUtils.sizeOfDirectory(File)).
-
-
Method Detail
-
compare
public int compare(java.io.File file1, java.io.File file2)Compare the length of two files.- Specified by:
comparein interfacejava.util.Comparator<java.io.File>- Parameters:
file1- The first file to comparefile2- The second file to compare- Returns:
- a negative value if the first file's length is less than the second, zero if the lengths are the same and a positive value if the first files length is greater than the second file.
-
toString
public java.lang.String toString()
String representation of this file comparator.- Returns:
- String representation of this file comparator
-
sort
public java.io.File[] sort(java.io.File... files)
Sort an array of files.This method uses
Arrays.sort(Object[], Comparator)and returns the original array.- Parameters:
files- The files to sort, may be null- Returns:
- The sorted array
- Since:
- 2.0
-
sort
public java.util.List<java.io.File> sort(java.util.List<java.io.File> files)
Sort a List of files.This method uses
Collections.sort(List, Comparator)and returns the original list.- Parameters:
files- The files to sort, may be null- Returns:
- The sorted list
- Since:
- 2.0
-
-