Retrofit初探——同步与异步请求

0x00 请求的形式

我们正常的网络请求有两种形式:同步方式和异步方式。所谓同步方式,是指我们发出网络请求之后当前线程被阻塞,直到请求的结果(成功或者失败)到来,才继续向下执行。所谓异步,是指我们的网络请求发出之后,不必等待请求结果的到来,就可以去做其他的事情,当请求结果到来时,我们在做处理结果的动作。当然无论是同步还是异步,最终都是同步请求。

0x01 同步请求

Retrofit的同步请求比较简单,直接调用 Call 的execute方法即可。这个时候我们会拿到请求的结果。

   @Test
    public void synchronousRequest() throws Exception {
        Retrofit retrofit = RetrofitManager.getRetrofit();
        GitHubService service = retrofit.create(GitHubService.class);
        Call<User> example = service.userInfo("ttdevs");
        Response<User> response = example.execute();
        print(response.body().getName());
    }

0x02 异步请求

之前文章的请求都是异步方式,在请求的回调中我们会拿到请求结果,接下来 处理这个结果即可。

@Test
    public void requestHeader() throws Exception {
        OkHttpClient client = RetrofitManager.getClient(new Interceptor() {
            @Override
            public okhttp3.Response intercept(Chain chain) throws IOException {
                Request original = chain.request();
                Request request = original.newBuilder()
                        .header("Time-Zone", "Asia/Shanghai") //https://developer.github.com/v3/#timezones
                        .header("user_key", "I_am_user_key")
                        .method(original.method(), original.body())
                        .build();
                okhttp3.Response response = chain.proceed(request);
                return response;
            }
        });
        Retrofit retrofit = RetrofitManager.getRetrofit(client);
        ExampleService service = retrofit.create(ExampleService.class);

        String url = "http://www.weather.com.cn/adat/sk/101020100.html";
        Call<ResponseBody> example = service.requestWithHeader(url);

        final CountDownLatch countDownLatch = new CountDownLatch(1);
        example.enqueue(new Callback<ResponseBody>() {
            @Override
            public void onResponse(Call<ResponseBody> call, Response<ResponseBody> response) {
                try {
                    print(response.body().string());
                } catch (IOException e) {
                    e.printStackTrace();
                }

                countDownLatch.countDown();
            }

            @Override
            public void onFailure(Call<ResponseBody> call, Throwable t) {
                countDownLatch.countDown();
            }
        });
        countDownLatch.await();
    }

总结

由于同步请求会阻塞当前线程,android的设计逻辑不能在主线程中发起网络请求(可能会导致ANR),所以我们比较常见的都是异步形式的网络请求。但是,有时候我们在工作线程中处理一些网络请求的时候,可以接受阻塞的情况(这个时候使用回调往往会使问题复杂化),那么我们就可以使用同步的方式来发起网络请求,比如,在使用Rxjava封装某个网络功能的逻辑是(如图片上传)我们就可以同步形式的网络请求。

—— EOF ——

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
以下是使用Retrofit2进行POST异步请求的示例代码: 1.首先,在build.gradle文件中添加Retrofit2和Gson的依赖: ```gradle dependencies { // Retrofit2 implementation 'com.squareup.retrofit2:retrofit:2.9.0' 'com.squareup.retrofit2:converter-gson:2.9.0' // Gson implementation 'com.google.code.gson:gson:2.8.6' } ``` 2.创建一个接口,用于定义POST请求的URL和参数: ```java public interface PostRequest_Interface { @POST("translate?doctype=json&jsonversion=&type=&keyfrom=&model=&mid=&imei=&vendor=&screen=&ssid=&network=&abtest=") @FormUrlEncoded Call<Translation1> getCall(@Field("i") String targetSentence); } ``` 3.创建一个实体类,用于接收服务器返回的JSON数据: ```java public class Translation1 { private int errorCode; private String query; private List<String> translation; // 省略getter和setter方法 } ``` 4.在Activity中发起POST异步请求: ```java public class MainActivity extends AppCompatActivity { private TextView mTvResult; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); mTvResult = findViewById(R.id.tv_result); // 创建Retrofit对象 Retrofit retrofit = new Retrofit.Builder() .baseUrl("http://fanyi.youdao.com/") .addConverterFactory(GsonConverterFactory.create()) .build(); // 创建网络请求接口实例 PostRequest_Interface request = retrofit.create(PostRequest_Interface.class); // 发起POST异步请求 Call<Translation1> call = request.getCall("hello"); call.enqueue(new Callback<Translation1>() { @Override public void onResponse(Call<Translation1> call, Response<Translation1> response) { Translation1 translation = response.body(); if (translation != null) { mTvResult.setText(translation.getTranslation().get(0)); } } @Override public void onFailure(Call<Translation1> call, Throwable t) { mTvResult.setText("请求失败:" + t.getMessage()); } }); } } ``` 在上述代码中,我们首先创建了一个Retrofit对象,并指定了请求的基础URL和Gson转换器。然后,我们创建了一个网络请求接口实例,并调用其中的getCall()方法发起POST异步请求。最后,我们在回调方法中处理服务器返回的数据。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值