3

我已经构建了一个使用 Okhttp 和改造的应用程序。除了一些不规则的有线行为外,一切正常。在这个新闻应用程序中,我触发了多个部分的提要下载请求。有时请求永远不会返回任何响应(甚至不会抛出异常)它只是卡住了,在 Logcat 中我看到连续的垃圾收集。

我试图找到潜在的嫌疑人发现找不到任何东西。我只能从 ddms 中的“线程”中看到很多线程处于“监控”状态(请看截图)

在此处输入图像描述

编辑: 另一个用于改造的常用线程转储:

在此处输入图像描述

这是改造配置:

public interface ApiService {
    @GET("/feed/get-news-feed/{section}")
    void getNewsArticles(
            @Path("section") String section, 
            Callback<GeneratedNewsEntryList> callback
    );
}

public static ApiService getInstance() {
    if(service == null) {
        OkHttpClient okHttpClient = new OkHttpClient();
        File cacheDir = App.getContext().getCacheDir();
        HttpResponseCache cache = null;
        try {
            cache = new HttpResponseCache(cacheDir, 1024);
        } catch (IOException e) {
            e.printStackTrace();
        }
        okHttpClient.setResponseCache(cache);

        RestAdapter restAdapter = new RestAdapter.Builder()
                .setServer(BASE_URL)
                .setClient(new OkClient(okHttpClient))
                .setErrorHandler(new ErrorHandler() {

                    @Override
                    public Throwable handleError(RetrofitError arg0) {
                        if(arg0.getResponse().getStatus() == 404)
                            return new Exception("Url does not exists");

                        return new Exception(arg0.getMessage());
                    }
                })
                .build();
        service = restAdapter.create(ApiService.class);
    }

    return service;
}

任何想法,有人遇到过类似的问题吗?

4

1 回答 1

0

看起来像是响应缓存中的错误,或者文件系统运行不佳。

响应缓存在将文件写入文件系统时持有锁,看起来其中一个写入没有很快完成。你能显示其他线程的线程转储吗?

于 2014-01-12T18:53:27.743 回答