我正在與java 8. 以下是案例:我有一個空界面AsyncResponse,如下所示:package com.personal.carrot.core.models;public interface AsyncResponse {}我有一個模型APIResponsepackage com.personal.carrot.core.models;import org.codehaus.jackson.annotate.JsonProperty;public class APIResponse implements AsyncResponse { @JsonProperty("numberOfFeatures") public Long numberOfFeatures;}最后我有一個服務Retrofit2用來做出我的 API 響應:public interface APIRepository { @POST("MYURL") Call<APIResponse> resolveCounts(@Body HashMap<String, String> body);}現在,當我像下面這樣調用 APIRepository 時:Call<AsyncResponse> request = repository.resolveCounts(payload);我收到一個錯誤:java:不兼容的類型:retrofit2.Call (com.personal.carrot.core.models.APIResponse) 無法轉換為retrofit2.Call(com.personal.carrot.core.models.AsyncResponse)
2 回答
滄海一幻覺
TA貢獻1824條經驗 獲得超5個贊
它失敗了,因為您不能將 a 分配Call<APIResponse>給 a Call<AsyncResponse>。泛型類型是不變的。
您可能必須將其APIResponse用作變量的類型參數:
Call<APIResponse> request = repository.resolveCounts(payload);
那不是因為你不能設計你的代碼來使用接口AsyncResponse,而是因為(我在這里假設)框架使用返回類型來處理與內容類型相關的綁定。
慕勒3428872
TA貢獻1848條經驗 獲得超6個贊
為什么它不起作用
與對多態性的普遍理解相反(這是您在此處嘗試完成的),它不適用于泛型。
List<String> strList = new ArrayList(); List<Object> objectList = strList;
上面的例子會產生編譯錯誤。
這是因為如果我們允許第二行成功,則可能會出現隨后objectList被分配另一種類型的列表(例如List<Integer>)的情況。strList現在將被“損壞”,因為與 .objectList具有相同的引用strList。
因此,我們需要返回與該列表明確聲明要保存的類型完全相同的類型,而不是 的子類或超類AsyncResponse。
潛在的解決方案
根據您在此處嘗試實現的目標,潛在的解決方案是:
Call<APIResponse> request = repository.resolveCounts(payload);
或(我還沒有嘗試過):
Call<? extends ASyncResponse> request = repository.resolveCounts(payload);
添加回答
舉報
0/150
提交
取消
