StrictMode가 활성화되면, 항상 FileReader에 DiskReadViolation이 있다고 불평합니다. 아무리 개선해도 계속 남아 있습니다. UIThread Lagging 문제와 관련이 있다고 생각합니다. 문제를 해결하는 방법을 알려주십시오. 안드로이드 StrictMode는 항상 FileReader에 대해 불평을합니다.
06-03 15:28:19.764: D/dalvikvm(5726): GC_CONCURRENT freed 1515K, 60% free 3122K/7751K, external 4429K/4959K, paused 19ms+14ms
06-03 15:28:19.803: D/StrictMode(5726): StrictMode policy violation; ~duration=216 ms: android.os.StrictMode$StrictModeDiskReadViolation: policy=23 violation=2
06-03 15:28:19.803: D/StrictMode(5726): at android.os.StrictMode$AndroidBlockGuardPolicy.onReadFromDisk(StrictMode.java:745)
06-03 15:28:19.803: D/StrictMode(5726): at dalvik.system.BlockGuard$WrappedFileSystem.open(BlockGuard.java:228)
06-03 15:28:19.803: D/StrictMode(5726): at java.io.FileInputStream.<init>(FileInputStream.java:80)
06-03 15:28:19.803: D/StrictMode(5726): at java.io.FileInputStream.<init>(FileInputStream.java:132)
06-03 15:28:19.803: D/StrictMode(5726): at java.io.FileReader.<init>(FileReader.java:66)
06-03 15:28:19.803: D/StrictMode(5726): at util.CpuUtil.getCpuFreq(CpuUtil.java:30)
public static float getCpuFreq() {
float result = -1;
FileReader fr = null;
BufferedReader br = null;
try {
fr = new FileReader("/sys/devices/system/cpu/cpu0/cpufreq/scaling_cur_freq");// (CpuUtil.java:30)
br = new BufferedReader(fr);
result = Float.parseFloat(br.readLine().trim());
result = result/1000;
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
} finally {
try {
if (fr != null) {
fr.close();
}
if (br != null) {
br.close();
}
} catch (IOException e) {
e.printStackTrace();
}
}
return result;
}
편집 : AsyncTask를에 넣어 getCpuFreq()하지만, onpostexcute의 잘못된 장소(). @rciovati, 당신의 상기시켜 주셔서 감사합니다, 그리고 plz 답변을 귀하의 단어를 그래서 나는 그것을 받아 들일 수 있습니다.
당신 안에 그 호출을 수행하는 시도 되세요 AsyncTask? – rciovati
죄송합니다. asynctask에 입력 했으므로 게시물을 업데이트 할 것입니다. – thecr0w
@rciovati, 당신의 상기시켜 주셔서 감사합니다, 그리고 plz 내가 답변을 수락 할 수 있도록 답변에 귀하의 단어를 게시 할 수 있습니다. – thecr0w