2013-06-03 7 views
1

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 답변을 귀하의 단어를 그래서 나는 그것을 받아 들일 수 있습니다.

+0

당신 안에 그 호출을 수행하는 시도 되세요 AsyncTask? – rciovati

+0

죄송합니다. asynctask에 입력 했으므로 게시물을 업데이트 할 것입니다. – thecr0w

+0

@rciovati, 당신의 상기시켜 주셔서 감사합니다, 그리고 plz 내가 답변을 수락 할 수 있도록 답변에 귀하의 단어를 게시 할 수 있습니다. – thecr0w

답변

1

사용을 고려 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 
     } 
    } 
} 
+0

BTW, 메모리 사용을 향상시키기 위해 닫은 후 fr/br를 null로 설정하는 것이 더 필요하다고 생각합니까? – thecr0w

0

가 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()); 
      });