私にはわかりにくい複雑な問題があります。このクラスでは、
の1つのarraylistリストから21のランダムなオブジェクトをarraylist finalChallengesに追加したいと思います。しかし、それは動作しません、時にはfinalChallangesは21個のオブジェクトを含んでいますが、ほとんどの場合オブジェクトの数は少なくなりますが、どこに問題があるのか分かりません。実際には、私はすべてのステップをコメントしようとしたが、何か間違っていたら、教えてください。それは非常に可能性の高い問題である: はfinalChallenges
が初期化されている場所が表示されませんし、我々はそれが応答ハンドラで非同期に上書きされて見ることができますユーザプロパティ、コンコードのないランダムオブジェクト..なぜ機能しないのですか?なぜ21のオブジェクトを取得しないのですか?
ArrayList<Challenges> listChallenges = new ArrayList<Challenges>();
ArrayList<Challenges> finalChallenges = new ArrayList<Challenges>(20);
//Check where the same userId and subscribers.objectId,
//Request these categories object and save to the ArrayList<Category> totalCategories
//Save these categories objectId to the selectedCategoriesId List<String>
BackendlessDataQuery query = new BackendlessDataQuery();
query.setWhereClause("subscribers.objectId = '"+backendlessUser.getObjectId()+"'");
Backendless.Data.of(Category.class).find(query, new AsyncCallback<BackendlessCollection<Category>>() {
@Override
public void handleResponse(BackendlessCollection<Category> categoriesBackendlessCollection) {
//add selected categories to totalActivities Category ArrayList
for(Category categories : categoriesBackendlessCollection.getData()) {
totalCategories.add(categories);
selectedCategoriesId.add(categories.getObjectId());
//
}
System.out.println(selectedCategoriesId);
//For cycle is going to selectedCategoriesId.size
//Check where the same category-objectId and actual selectedCategoriesId
//Request these challenges object, which are in the actual category and save to the ArrayList<Challenges> listChallenges
//Save these categories objectId to the selectedCategoriesId List<String>
for(int k=0;k<selectedCategoriesId.size();k++) {
BackendlessDataQuery query = new BackendlessDataQuery();
query.setPageSize(pageSize);
query.setWhereClause("category.objectId = '" + selectedCategoriesId.get(k) + "'");
Backendless.Data.of(Challenges.class).find(query, new AsyncCallback<BackendlessCollection<Challenges>>() {
@Override
public void handleResponse(BackendlessCollection<Challenges> cha) {
for (Challenges challenges : cha.getData()) {
listChallenges.add(challenges);
challengeTitle.add(challenges.getChallengeTitle());
challengeContent.add(challenges.getChallengeContent());
challangeId.add(challenges.getObjectId());
}
System.out.println("osszes elem:"+listChallenges);
//ArrayList<Challenges> finalChallenges size is 21 with 0
// get from listChallenges random 21 object without concord and add to the finalChallenges
Random random = new Random();
List<Challenges> temp = new ArrayList<>(listChallenges);
ArrayList<Challenges> tempNewList = new ArrayList<Challenges>();
//ArrayList<Challenges> temp = new ArrayList<Challenges>(listChallenges.size());
for (Challenges item : listChallenges) temp.add(item);
while (finalChallenges.size()<21 && temp.size()>0) {
int index = random.nextInt(temp.size());
tempNewList.add(temp.get(index));
temp.remove(index);
finalChallenges= tempNewList;
}
// System.out.println("kihívások");
System.out.println(finalChallenges);
System.out.println(finalChallenges.size());
// title.setText(challengeTitle.get(0));
// content.setText(challengeContent.get(0));
// objectId = challangeId.get(0);
}
@Override
public void handleFault(BackendlessFault fault) {
}
});
//save finalChallenges array objects to the current user "userChallenges" relationship
Backendless.UserService.login(email, password, new AsyncCallback<BackendlessUser>() {
@Override
public void handleResponse(BackendlessUser backendlessUser) {
backendlessUser.setProperty("userChallenges",new ArrayList<>(finalChallenges));
}
});
Backendless.UserService.update(backendlessUser, new BackendlessCallback<BackendlessUser>() {
@Override
public void handleResponse(BackendlessUser response) {
System.out.println("User has been updated");
}
@Override
public void handleFault(BackendlessFault fault) {
System.out.println("User has not been updated");
}
});
}
@Override
public void handleFault(BackendlessFault backendlessFault) {
System.out.println("Server reported an error - " + backendlessFault.getMessage());
}
},true);
}
}
@Override
public void handleFault(BackendlessFault fault) {
}
});
答えをありがとう。私は編集しました。実際にそれは非常にうまく動作します、私はあなたの答えを受け入れるつもりですが、あなたはなぜユーザープロパティのオブジェクトを設定するのを助けることができますか?例えば、finalCHALLENESはconatins 21を、プロパティはちょうど12を加えます。あなたが私がgreatfullになるのを助けることができる場合 – Storg
申し訳ありませんあなたの質問を理解していない。ここでは非常に遅いですが、今は出発しなければなりませんが、明日は必要に応じて詳細を説明することができます。 –
ありがとう、私は今のようにどのように見えるのかという質問のコードを編集しました。 – Storg