Как я могу отладить doInBackground код AsyncTask - PullRequest
17 голосов
/ 13 августа 2011

У меня установлены точки останова, но они, кажется, игнорируются (или никогда не видны).

Мой код ниже. Я пытаюсь сделать резервную копию sql db на SD-карту.

Когда я запускаю его (не в режиме отладки) в eclipse, я получаю сообщение от onPreExecute, а затем коротко сообщение от onPostExecute.

У меня есть BreakPoints, установленные почти в каждой строке ExportDatabaseFileTask.

Когда я запускаю его (в режиме отладки) в eclipse, я останавливаюсь на точках останова в onPreExecute, а затем, когда я продвигаюсь дальше, ОЧЕНЬ СЛЕДУЮЩАЯ ЛИНИЯ, к которой идет отладчик:

mDbHelper.open ();

Затем я перехожу через остальную часть нормального кода и остаюсь в AVD, показывающем сообщение от onPreExecute, когда оно, очевидно, останется навсегда.

Я НЕ вижу ни одной из линий, НАЗНАЧЕННЫХ в:

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();
            }
        }
    }
* *} Тысяча двадцать-один

Ответы [ 5 ]

41 голосов
/ 01 сентября 2011

проверьте это Как использовать отладчик Eclipse в AsyncTask при разработке для Android?

Поместите следующий фрагмент кода в начало doInBackground()

if(android.os.Debug.isDebuggerConnected())
    android.os.Debug.waitForDebugger();

Затем, когда вы установите точку останова в этом потоке, затмение найдет ее.

Предоставлено: sargas

4 голосов
/ 15 января 2016

В вашем 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..
}

`

4 голосов
/ 13 августа 2011

Если они игнорируются, то, вероятно, это одно из двух:

  1. Вы запускаете проект не в режиме отладки.
  2. Вы никогда не достигаете этих строк во время выполнения.
1 голос
/ 15 сентября 2017

Если в фоновом режиме выполняется другая асинхронная задача, то, возможно, новая будет пропущена, чтобы запустить метод doinbackground, поэтому попробуйте выполнить так:

(new ExampleAsyncTask()).executeOnExecutor(AsyncTask.THREAD_POOL_EXECUTOR);
0 голосов
/ 11 мая 2017

Я столкнулся с чем-то похожим в Android Studio.Для меня это было связано с активностью Proguard во время отладки.Proguard испортил номера строк после минимизации.Вы можете отключить Proguard, удалив minfyEnabled true из вашего build.gradle

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...