2 回答

TA貢獻1854條經驗 獲得超8個贊
有一種解決此問題的常用方法,即定義一個回調方法,在調用填充這些值后將這些值返回給您,就像這樣(我的 java 生銹了,請耐心等待.. .)
定義一個接口:
interface Callback{
void apiResponseCallback(ArrayList<Page> result);//whatever your model is, make the array of that type
}
然后,在您的常規 findPages 方法中,將其更改為:
public void findPages(Callback callback) {
//
//
........
for(int i=0; i < jsonObject.getJSONArray("data").length(); i++)
{
page = response.getJSONObject().getJSONArray("data").getJSONObject(i).getString("name");
Log.d("viewmodel",page);
foundPages.add(page);
}
callback.apiResponseCallback(foundPages);//here we are returning the data when it is done
}
然后,當你打電話findPages
findPages(new Callback() {
@Override
public void apiResponseCallback(ArrayList<Page> result) {
here, this result parameter that comes through is your api call result to use, so result will be your populated pages to use.
}
});
}
為了完整性:
public void findPages(Callback callback)
{
accessToken = AccessToken.getCurrentAccessToken();
foundPages = new ArrayList<>();
GraphRequest request = GraphRequest.newGraphPathRequest(
accessToken,
"/me/accounts",
new GraphRequest.Callback() {
@Override
public void onCompleted(GraphResponse response) {
try {
jsonObject = response.getJSONObject();
for(int i=0; i < jsonObject.getJSONArray("data").length(); i++)
{
page = response.getJSONObject().getJSONArray("data").getJSONObject(i).getString("name");
Log.d("viewmodel",page);
foundPages.add(page);
}
callback.apiResponseCallback(foundPages);
} catch (JSONException e) {
e.printStackTrace();
}
}
});
request.executeAsync();
}

TA貢獻1862條經驗 獲得超7個贊
是的。這里:
request.executeAsync();
觸發異步請求。但是你的“當前”線程只是繼續做:
return foundPages;
它返回一個空列表。
該列表稍后會被填充,但在該方法返回的那一刻,該列表仍然是空的?;蛘咧皇潜惶顫M。誰知道呢,因為它會在未來某個未知的時間點異步填充。
一個解決方案可能是讓一些其他變量/字段告訴您數據已到達并推入列表。
或者,該方法可以只發出一個同步請求,簡單地阻止調用者繼續進行,直到數據到達。
你看,你不能兩全其美:當你不等待結果到達時,你不應該期望它們立即可用。
添加回答
舉報