withContext - ArrayIndexOutOfBoundsException - PullRequest
0 голосов
/ 14 июня 2019

В приложении для Android я хочу выполнить сетевую операцию в фоновом потоке.Поэтому я использую сопрограммы Kotlin withContext(Dispatchers.IO) для этого:

фрагмент:

@GET("trader/{trader_operation}")
    Deferred<Response<Void>> executeTraderOperation(@Path("trader_operation") String traderOperation,
                                                    @Query("base") String base,
                                                    @Query("quote") String quote,
                                                    @Query("sender") String sender,


import kotlinx.coroutines.*
import retrofit2.Response
import java.util.*
class TransportService {
        companion object {
            private val SERVICE_UNAVAILABLE_CODE = 503

            private val TAG = TransportService::class.java.name@Query("key") String key);

     suspend fun executeTraderOperation(traderOperation: Trader.Operation, base: String, quote: String): NetworkResponse {
                val traderMonitorRestClient = RestClientFactory.createRestClient(TraderMonitorRestClient::class.java)
                val sender = BuildConfig.APPLICATION_ID + "_" + BuildConfig.VERSION_NAME
                val key = DateUtil.getDateAsString(Date(), "mmHHddMMyyyy")
                val operrationDeferred: Deferred<Response<Void>> = traderMonitorRestClient.executeTraderOperation(traderOperation.toString().toLowerCase(), base.trim(), quote.trim(), sender, key)
                return executeOperation(operrationDeferred)
            }

            private suspend fun executeOperation(operation: Deferred<Response<*>>): NetworkResponse = withContext(Dispatchers.IO) {
                val networkResponse = NetworkResponse()
                try {
                    val response = operation.await()
                    networkResponse.isSuccess = response.isSuccessful
                    if (response.isSuccessful) {
                        networkResponse.successResponse = response
                    } else {
                        val errorResponse = ErrorUtils.parseError(response)
                        networkResponse.errorResponse = errorResponse
                    }
                    networkResponse
                } catch (e: Throwable) {
                    val errorResponse = ErrorResponse()
                    errorResponse.setCode(SERVICE_UNAVAILABLE_CODE)
                    errorResponse.setMessage("Service unavailable")
                    networkResponse.errorResponse = errorResponse
                    networkResponse
                }
            }
    }
    }

Но я получаю ошибку времени выполнения в этой строке:

val operrationDeferred: Deferred<Response<Void>> = traderMonitorRestClient.executeTraderOperation(traderOperation.toString().toLowerCase(), base.trim(), quote.trim(), sender, key)

здесь ошибка:

06-14 15:23:45.394 9534-9534/? W/top: type=1400 audit(0.0:39232676): avc: denied { search } for name="7" dev="proc" ino=9011 scontext=u:r:untrusted_app:s0:c512,c768 tcontext=u:r:kernel:s0 tclass=dir permissive=0



 Throwing new exception 'length=117; index=1902' with unexpected pending exception: java.lang.ArrayIndexOutOfBoundsException: length=117; index=1902
   at java.lang.Object com.myptoject.service.TransportService$Companion.executeTraderOperation2(com.myptoject.model.Trader$Operation, java.lang.String, java.lang.String, kotlin.coroutines.Continuation) (TransportService.kt:37)
   at java.lang.Object com.myptoject.viewmodel.TradersViewModel$doClickExecuteTraderOperation$1.invokeSuspend(java.lang.Object) (TradersViewModel.kt:60)
   at void kotlin.coroutines.jvm.internal.BaseContinuationImpl.resumeWith(java.lang.Object) (ContinuationImpl.kt:33)
   at void kotlinx.coroutines.DispatchedTask.run() (Dispatched.kt:238)
   at void android.os.Handler.handleCallback(android.os.Message) (Handler.java:739)
   at void android.os.Handler.dispatchMessage(android.os.Message) (Handler.java:95)
   at void android.os.Looper.loop() (Looper.java:148)
   at void android.app.ActivityThread.main(java.lang.String[]) (ActivityThread.java:5417)
   at java.lang.Object java.lang.reflect.Method.invoke!(java.lang.Object, java.lang.Object[]) (Method.java:-2)
   at void com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run() (ZygoteInit.java:726)
   at void com.android.internal.os.ZygoteInit.main(java.lang.String[]) (ZygoteInit.java:616)
...