Inner class can access but not update values - AsyncTask
Внутренний класс может получать доступ, но не обновлять значения - AsyncTask
Я пытаюсь разархивировать папку с помощью Android AsyncTask. Класс (называемый Decompress) является внутренним классом Unzip, где Unzip сам по себе является классом, не требующим активности. Псевдокод является:
1. Значение unzipDest и index, обновленные в doInBackground, остаются нулевыми для Unzip и всех его объектов. Как я могу гарантировать, что значения остаются обновленными?
2. Я знаю, что doInBackground выполняется в потоке, отдельном от основного потока пользовательского интерфейса. Означает ли это, что любые значения, обновленные в новом потоке, будут потеряны, как только этот поток вернется?
Переведено автоматически
Ответ 1
Как я могу гарантировать, что значения остаются обновленными?
Они будут обновлены, поскольку являются переменными-членами. Однако, поскольку AsyncTask является асинхронным, они могут еще не обновляться при их проверке. Вы можете использовать interface для создания обратного вызова при обновлении этих значений. Этот ответ SO описывает, как это сделать
Означает ли это, что любые значения, обновленные в новом потоке, будут потеряны, как только этот поток вернется?
Нет, они не должны быть "потеряны". Вероятно, они просто не были изменены в AsyncTask когда вы их проверяете.
Поскольку это не ваш реальный код, я не вижу, когда вы пытаетесь получить к ним доступ, но вы можете использовать interface метод или вызвать функции, которым нужны эти значения в onPostExecute(). Вы также можете выполнить null проверку, прежде чем пытаться получить к ним доступ. Это просто зависит от функциональности и потока, который вам нужен, относительно того, какой способ лучше. Надеюсь, это поможет.
Редактировать
В ответе, на который я ссылался, вы сообщаете Activity, что будете использовать это interface и переопределяете его методы с помощью implements AsyncResponse в вашем Activity объявлении после создания отдельного interface class
publicclassMainActivityimplementsAsyncResponse{
затем, в вашем Activity по-прежнему, вы переопределяете метод, который вы объявили в этом классе (void processFinish(String output);)
@Override voidprocessFinish(String output){ // using same params as onPostExecute() //this you will received result fired from async class of onPostExecute(result) method. }
затем это вызывается в onPostExecute() когда слушатель видит, что это сделано с delegate.processFinish(result);delegate экземпляром AsyncResponse (вашего класса интерфейса)
publicclassAasyncTaskextendsAsyncTask{ public AsyncResponse delegate=null;
Interface пример взят из связанного ответа выше и скорректирован / прокомментирован для наглядности. Поэтому обязательно поддержите этот ответ, если он кому-то поможет.