Как я могу отлаживать код doInBackground для AsyncTask
У меня установлены точки останова, но они, кажется, игнорируются (или никогда не видны).
Мой код ниже. Я пытаюсь сделать резервную копию sql db на SD-карту.
Когда я запускаю его (не режим Debug) в eclipse, я получаю сообщение от onPreExecute и вскоре за ним следует сообщение из onPostExecute.
У меня есть точки прерывания, установленные почти в каждой строке объекта ExportDatabaseFileTask.
Когда я запускаю его (в режиме отладки) в eclipse, я останавливаюсь на контрольных точках в onPreExecute, а затем, когда я продвигаюсь дальше, ОЧЕНЬ СЛЕДУЮЩАЯ ЛИНИЯ, к которой отладчик идет, есть:
mDbHelper.open();
Затем я перехожу через остальную часть нормального кода и оставляю AVD, показывая сообщение из onPreExecute, если он, по-видимому, будет STAY FOREVER.
Я НЕ вижу ни одной из строк BREAKPOINTED в:
doInBackground
onPostExecute
CopyFile
Итак, я должен уважительно не соглашаться с комментарием, что у меня его нет, или он не выполняется. Итак, я задам свой вопрос: как вы отлаживаете (STEP THROUGH) doInBackground код AsyncTask?
case BACKUP_ID:
if (ScoreAGame.this.isExternalStorageAvail()) {
mDbHelper.close();
new ExportDatabaseFileTask().execute();
mDbHelper.open();
} else {
Toast.makeText(ScoreAGame.this, "External storage is not available, unable to export data.",
Toast.LENGTH_SHORT).show();
}
return true;
case RESTORE_ID:
selectCourse();
return true;
}
return super.onMenuItemSelected(featureId, item);
}
private boolean isExternalStorageAvail() {
return Environment.getExternalStorageState().equals(Environment.MEDIA_MOUNTED);
}
private class ExportDatabaseFileTask extends AsyncTask<String, Void, Boolean> {
private final ProgressDialog dialog = new ProgressDialog(ScoreAGame.this);
// can use UI thread here
protected void onPreExecute() {
this.dialog.setMessage("Exporting database...");
this.dialog.show();
}
// automatically done on worker thread (separate from UI thread)
protected Boolean doInBackground(final String... args) {
File dbFile =
new File(Environment.getDataDirectory() + "/data/com.discgolf/databases/discgolfdb.db");
File exportDir = new File(Environment.getExternalStorageDirectory(), "discgolfbackup");
if (!exportDir.exists()) {
exportDir.mkdirs();
}
File file = new File(exportDir, dbFile.getName());
try {
file.createNewFile();
this.copyFile(dbFile, file);
return true;
}
catch (IOException e) {
Log.e(TAG, e.getMessage(), e);
return false;
}
}
// can use UI thread here
protected void onPostExecute(final Boolean success) {
if (this.dialog.isShowing()) {
this.dialog.dismiss();
}
if (success) {
Toast.makeText(ScoreAGame.this, "Export successful!", Toast.LENGTH_SHORT).show();
} else {
Toast.makeText(ScoreAGame.this, "Export failed", Toast.LENGTH_SHORT).show();
}
}
void copyFile(File src, File dst) throws IOException {
FileChannel inChannel = new FileInputStream(src).getChannel();
FileChannel outChannel = new FileOutputStream(dst).getChannel();
try {
inChannel.transferTo(0, inChannel.size(), outChannel);
}
finally {
if (inChannel != null) {
inChannel.close();
}
if (outChannel != null) {
outChannel.close();
}
}
}
}
Ответы
Ответ 1
проверить это Как использовать отладчик Eclipse в AsyncTask при разработке для Android?
Поместите следующий фрагмент кода в начало doInBackground()
if(android.os.Debug.isDebuggerConnected())
android.os.Debug.waitForDebugger();
Затем, когда вы установите точку останова в этом потоке, eclipse найдет ее.
Предоставлено: sargas
Ответ 2
В doInBackground() добавьте следующее.
protected Integer doInBackground(String... params) {
// for debug worker thread
if(android.os.Debug.isDebuggerConnected())
android.os.Debug.waitForDebugger();
// create the file with the given file path
File file = new File(params[0]);
// enter rest of the code here..
}
`
Ответ 3
Если они игнорируются, то это, вероятно, одно из двух:
- Вы запускаете проект не в режиме отладки.
- Вы никогда не достигаете этих строк во время выполнения.
Ответ 4
В Android Studio я столкнулся с чем-то подобным. Для меня это было связано с активностью Proguard во время отладки. Proguard испортил номера строк после извлечения. Вы можете отключить Proguard, удалив minfyEnabled true
из вашего build.gradle
Ответ 5
Если в фоновом режиме запущена другая задача Async, тогда может быть новый скип для запуска метода doinbackground, поэтому попробуйте запустить как:
(new ExampleAsyncTask()).executeOnExecutor(AsyncTask.THREAD_POOL_EXECUTOR);