編輯:關於android開發
有時候要做出如下所示的展示文件大小的效果時候,需要對文件大小進行轉換,然後再進行相關的代碼邏輯編寫。
/***
* 存儲大小(單位)轉換器.
*/
public enum SizeConverter {
/**
* 轉換任意單位的大小, 返回結果會包含兩位小數但不包含單位.
*/
Arbitrary {
@Override
public String convert(float size) {
while (size > 1024) {
size /= 1024;
}
return String.format(FORMAT_F, size);
}
},
// -----------------------------------------------------------------------
// 有單位
/**
* 轉換單位為B的大小, 返回結果會包含兩位小數以及單位. 如: 1024B->1KB, (1024*1024)B->1MB
*/
B {
@Override
public String convert(float B) {
return converter(0, B);
}
},
/**
* 轉換單位為KB的大小, 返回結果會包含兩位小數以及單位.
*/
KB {
@Override
public String convert(float KB) {
return converter(1, KB);
}
},
/**
* 轉換單位為MB的大小, 返回結果會包含兩位小數以及單位.
*/
MB {
@Override
public String convert(float MB) {
return converter(2, MB);
}
},
/**
* 轉換單位為GB的大小, 返回結果會包含兩位小數以及單位.
*/
GB {
@Override
public String convert(float GB) {
return converter(3, GB);
}
},
/**
* 轉換單位為TB的大小, 返回結果會包含兩位小數以及單位.
*/
TB {
@Override
public String convert(float TB) {
return converter(4, TB);
}
},
// -----------------------------------------------------------------------
// trim沒單位
/**
* 轉換任意單位的大小, 返回結果小數部分為0時將去除兩位小數, 不包含單位.
*/
ArbitraryTrim {
@Override
public String convert(float size) {
while (size > 1024) {
size /= 1024;
}
int sizeInt = (int) size;
boolean isfloat = size - sizeInt > 0.0F;
if (isfloat) {
return String.format(FORMAT_F, size);
}
return String.format(FORMAT_D, sizeInt);
}
},
// -----------------------------------------------------------------------
// trim有單位
/**
* 轉換單位為B的大小, 返回結果小數部分為0時將去除兩位小數, 會包含單位.
*/
BTrim {
@Override
public String convert(float B) {
return trimConverter(0, B);
}
},
/**
* 轉換單位為KB的大小, 返回結果小數部分為0時將去除兩位小數, 會包含單位.
*/
KBTrim {
@Override
public String convert(float KB) {
return trimConverter(1, KB);
}
},
/**
* 轉換單位為MB的大小, 返回結果小數部分為0時將去除兩位小數, 會包含單位.
*/
MBTrim {
@Override
public String convert(float MB) {
return trimConverter(2, MB);
}
},
/**
* 轉換單位為GB的大小, 返回結果小數部分為0時將去除兩位小數, 會包含單位.
*/
GBTrim {
@Override
public String convert(float GB) {
return trimConverter(3, GB);
}
},
/**
* 轉換單位為TB的大小, 返回結果小數部分為0時將去除兩位小數, 會包含單位.
*/
TBTrim {
@Override
public String convert(float TB) {
return trimConverter(4, TB);
}
};
/***
*
將指定的大小轉換到1024范圍內的大小. 注意該方法的最大單位為PB, 最小單位為B, * 任何超出該范圍的單位最終會顯示為**.
* * @param size 要轉換的大小, 注意是浮點數, 不要以整形的方式傳入, 容易造成溢出. * (如: 1024*1024*1024*1024*1024會溢出, 使結果為0, 因為它先將結果以int相乘後再轉換為float; * 而1024.0F*1024.0F*1024.0F*1024.0F*1024.0F就不會溢出) * @return */ abstract public String convert(float size); // ----------------------------------------------------------------------- // 單位轉換 private static final String[] UNITS = new String[]{ "B", "KB", "MB", "GB", "TB", "PB", "**" }; private static final int LAST_IDX = UNITS.length - 1; private static final String FORMAT_F = "%1$-1.2f"; private static final String FORMAT_F_UNIT = "%1$-1.2f%2$s"; private static final String FORMAT_D = "%1$-1d"; private static final String FORMAT_D_UNIT = "%1$-1d%2$s"; // ----------------------------------------------------------------------- private static String converter(int unit, float size) { int unitIdx = unit; while (size > 1024) { unitIdx++; size /= 1024; } int idx = unitIdx < LAST_IDX ? unitIdx : LAST_IDX; return String.format(FORMAT_F_UNIT, size, UNITS[idx]); } private static String trimConverter(int unit, float size) { int unitIdx = unit; while (size > 1024) { unitIdx++; size /= 1024; } int sizeInt = (int) size; boolean isfloat = size - sizeInt > 0.0F; int idx = unitIdx < LAST_IDX ? unitIdx : LAST_IDX; if (isfloat) { return String.format(FORMAT_F_UNIT, size, UNITS[idx]); } return String.format(FORMAT_D_UNIT, sizeInt, UNITS[idx]); } // ----------------------------------------------------------------------- public static String convertBytes(float B, boolean trim) { return trim ? trimConvert(0, B, true) : convert(0, B, true); } public static String convertKB(float KB, boolean trim) { return trim ? trimConvert(1, KB, true) : convert(1, KB, true); } public static String convertMB(float MB, boolean trim) { return trim ? trimConvert(2, MB, true) : convert(2, MB, true); } /*** *
存儲大小單位間的轉換. 注意該方法的最大單位為PB, 最小單位為B, * 任何超出該范圍的單位最終會顯示為**.
* * @param unit 從哪個單位開始 * @param size 存儲大小, 注意是float, 不要以整形的形式傳入, 否則會溢出(如:1024*1024這種, * 它是先將1024*1024作為int相乘再轉換為float的, 如果值過大的話就會溢出了, * 所以這麼寫1024.0F*1024.0F) * @param withUnit 返回的結果字符串是否帶有對應的單位 * @return */ private static String convert(int unit, float size, boolean withUnit) { int unitIdx = unit; while (size > 1024) { unitIdx++; size /= 1024; } if (withUnit) { int idx = unitIdx < LAST_IDX ? unitIdx : LAST_IDX; return String.format(FORMAT_F_UNIT, size, UNITS[idx]); } return String.format(FORMAT_F, size); } /*** *
存儲大小單位間的轉換, 如果轉換後小數部分為0, 則去除小數部分. * 注意該方法的最大單位為PB, 最小單位為B, 任何超出該范圍的單位最終會顯示為**.
* * @param unit 從哪個單位開始 * @param size 存儲大小, 注意是float, 不要以整形的形式傳入, 否則會溢出(如:1024*1024這種, * 它是先將1024*1024作為int相乘再轉換為float的, 如果值過大的話就會溢出了, * 所以這麼寫1024.0F*1024.0F) * @param withUnit 返回的結果字符串是否帶有對應的單位 * @return */ private static String trimConvert(int unit, float size, boolean withUnit) { int unitIdx = unit; while (size > 1024) { unitIdx++; size /= 1024; } int sizeInt = (int) size; boolean isfloat = size - sizeInt > 0.0F; if (withUnit) { int idx = unitIdx < LAST_IDX ? unitIdx : LAST_IDX; if (isfloat) { return String.format(FORMAT_F_UNIT, size, UNITS[idx]); } return String.format(FORMAT_D_UNIT, sizeInt, UNITS[idx]); } if (isfloat) { return String.format(FORMAT_F, size); } return String.format(FORMAT_D, sizeInt); } }
下面用一個測試類來測試一下
public class SizeConverterTest {
public static void main(String[] args) {
System.out.println(SizeConverter.BTrim.convert(6808055f));
System.out.println(SizeConverter.BTrim.convert(11475968f));
System.out.println(SizeConverter.BTrim.convert(5013547f));
System.out.println(SizeConverter.BTrim.convert(12623539f));
}
}
輸出結果為:
6.49Mb
10.94Mb
4.78Mb
12.04Mb
Android-->Genymotion虛擬機(模擬器)的配置,genymotion模擬器配置 --> Genymotion 是一套完整
算法—符號表,算法符號定義:符號表是一種存儲鍵值對的數據結構,支持兩種操作:插入(put),即將一組新的鍵值對存入表中;查找(get),即根據給定的鍵得到相應的值。 1
android開發環境以及genymotion虛擬機配合HBuilder測試(自總結),genymotionhbuilder一、安裝android-studio http
解析網絡json數據,模擬美團界面顯示。,json 1 <?xml version=1.0 encoding=UTF-8?> 2 <RelativeL