賢明な単位を使用して、ファイルサイズを文字列として表示する必要があります。
例えば.
1L ==> "1 B";
1024L ==> "1 KB";
2537253L ==> "2.3 MB"
等.
この前の回答 が見つかりましたが、満足のいくものではありませんでした
私は同様の欠点を持つ独自のソリューションを考え出しました:
private static final long K = 1024;
private static final long M = K * K;
private static final long G = M * K;
private static final long T = G * K;
public static String convertToStringRepresentation(final long value){
final long[] dividers = new long[] { T, G, M, K, 1 };
final String[] units = new String[] { "TB", "GB", "MB", "KB", "B" };
if(value < 1)
throw new IllegalArgumentException("Invalid file size: " + value);
String result = null;
for(int i = 0; i < dividers.length; i++){
final long divider = dividers[i];
if(value >= divider){
result = format(value, divider, units[i]);
break;
}
}
return result;
}
private static String format(final long value,
final long divider,
final String unit){
final double result =
divider > 1 ? (double) value / (double) divider : (double) value;
return String.format("%.1f %s", Double.valueOf(result), unit);
}
主な問題は、DecimalformatやString.formatについての私の限られた知識です。 1 KB
ではなく1.0 KB
に1024L、1025Lなどをマップしたいと思います。
したがって、2つの可能性:
public static String readableFileSize(long size) {
if(size <= 0) return "0";
final String[] units = new String[] { "B", "kB", "MB", "GB", "TB" };
int digitGroups = (int) (Math.log10(size)/Math.log10(1024));
return new DecimalFormat("#,##0.#").format(size/Math.pow(1024, digitGroups)) + " " + units[digitGroups];
}
これは最大1000 TBまで動作します。..プログラムは短いです!
おそらくJava.text.DecimalFormat
でさらに運が上がるでしょう。このコードはおそらくそれを行う必要があります(ただし、単にウィングします...)
new DecimalFormat("#,##0.#").format(value) + " " + unit
驚いたことに、ループベースのアルゴリズムは約10%高速です。
public static String toNumInUnits(long bytes) {
int u = 0;
for (;bytes > 1024*1024; bytes >>= 10) {
u++;
}
if (bytes > 1024)
u++;
return String.format("%.1f %cB", bytes/1024f, " kMGTPE".charAt(u));
}