Android StrictMode всегда жалуется на FileReader

Когда StrictMode включен, он всегда жалуется, что FileReader имеет DiskReadViolation. Как бы я не улучшался, он все еще там. Я подозреваю, что это как-то связано с проблемой отставания UIThread, пожалуйста, дайте мне знать, как это исправить, спасибо.

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;
}

РЕДАКТИРОВАТЬ: getCpuFreq() помещается в асинтаск, но не в том месте onpostexcute(). @rciovati, спасибо за напоминание, и, пожалуйста, опубликуйте свои слова в ответах, чтобы я мог их принять.


person thecr0w    schedule 03.06.2013    source источник
comment
Вы пытались выполнить этот вызов внутри AsyncTask ?   -  person rciovati    schedule 03.06.2013
comment
Извините, я поместил это в асинтаск, я обновлю свой пост.   -  person thecr0w    schedule 03.06.2013
comment
@rciovati, спасибо за напоминание, и, пожалуйста, опубликуйте свои слова в ответах, чтобы я мог их принять.   -  person thecr0w    schedule 03.06.2013


Ответы (2)


Рассмотрите возможность использования AsyncTask:

public class MainActivity extends Activity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        new YourAsyncTask().execute();
    }

    static class YourAsyncTask  extends AsyncTask<Void, Void, String> {

        @Override
        protected String doInBackground(Void... unused) {
            //Put your code inside here
        }
    }
}
person rciovati    schedule 03.06.2013
comment
Кстати, как вы думаете, необходимо дополнительно установить fr / br в ноль после закрытия, чтобы улучшить использование памяти? - person thecr0w; 04.06.2013

Вот версия RxJava:

public Observable<Float> getFreq() {
    return Observable
            .create(subscriber -> {
                try {
                    float result = -1;
                    FileReader fr = null;
                    BufferedReader br = null;
                    try {
                        fr = new FileReader("/sys/devices/system/cpu/cpu0/cpufreq/scaling_cur_freq");
                        br = new BufferedReader(fr);
                        result = Float.parseFloat(br.readLine().trim());
                        result = result / 1000;
                    } finally {
                        if (fr != null) {
                            fr.close();
                        }
                        if (br != null) {
                            br.close();
                        }
                    }
                    subscriber.onNext(result);
                    subscriber.onCompleted();
                } catch (IOException e) {
                    subscriber.onError(e);
                }
            })
            .cast(Float.class)
            .subscribeOn(Schedulers.io());
}

И вот как это использовать:

    getFreq()
            .observeOn(AndroidSchedulers.mainThread())
            .subscribe(freq -> {
                App.L.debug(freq.toString());
            }, error -> {
                App.L.error(error.toString());
            });
person Ivan Morgillo    schedule 11.05.2015