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;
它返回一个空列表。
该列表稍后会被填充,但在该方法返回的那一刻,该列表仍然是空的。或者只是被填满。谁知道呢,因为它会在未来某个未知的时间点异步填充。
一个解决方案可能是让一些其他变量/字段告诉您数据已到达并推入列表。
或者,该方法可以只发出一个同步请求,简单地阻止调用者继续进行,直到数据到达。
你看,你不能两全其美:当你不等待结果到达时,你不应该期望它们立即可用。
添加回答
举报