Android - Модернизация медленная по сравнению со скриптом python - PullRequest
2 голосов
/ 02 апреля 2020

Я использую Retrofit2 в своем приложении Android, но я испытываю большую медлительность в вызовах по сравнению с теми же вызовами, совершаемыми через скрипт Python. Смартфон Android и p c, на котором выполняется скрипт, используют одно и то же соединение inte rnet.

Например, вызов GET (406 байт) в среднем занимает следующее время:

  • Android Приложение: 525мс
  • Python скрипт: 111мс
  • Safari: 109мс

Первый вызов GET (3140 байт) имеет самая большая разница:

  • Android Приложение: 1723ms
  • Python скрипт или Safari: 294ms

My Retrofit API Код класса:

    import java.util.concurrent.TimeUnit;

    import okhttp3.OkHttpClient;
    import okhttp3.logging.HttpLoggingInterceptor;
    import retrofit2.Retrofit;
    import retrofit2.converter.gson.GsonConverterFactory;

    class APIClient {

        private static Retrofit retrofit = null;
        private static String url = "http://test.mylink.com";

        static Retrofit getClient() {

            HttpLoggingInterceptor interceptor = new HttpLoggingInterceptor();
            interceptor.setLevel(HttpLoggingInterceptor.Level.BODY);
            OkHttpClient client = new OkHttpClient.Builder()
                                    .readTimeout(60, TimeUnit.SECONDS)
                                    .connectTimeout(60, TimeUnit.SECONDS)
                                    .addInterceptor(interceptor).build();

            retrofit = new Retrofit.Builder()
                    .baseUrl(url)
                    .addConverterFactory(GsonConverterFactory.create())
                    .client(client)
                    .build();

            return retrofit;
        }

    }

API-вызовы выполняются внутри потока

class TestClass extends Thread {
     ...
     public void makeCall() {
            Call<Proof> call1 = _apiInterface.getProof();
            call1.enqueue(new Callback<Proof>() {
                @Override
                public void onResponse(Call<Proof> call, Response<Proof> response) {
                    ...
                }

                @Override
                public void onFailure(Call<Proof> call, Throwable t) {
                    call.cancel();
                    ...
                }
            });
     }
}

У кого-нибудь была подобная проблема с Retrofit?

...