Я использую 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?