gpt4 book ai didi

java - 比较两个列表并对添加和删除的条目进行排序

转载 作者:太空宇宙 更新时间:2023-11-04 12:46:50 27 4
gpt4 key购买 nike

我正在尝试比较两个列表,并将添加的条目放入一个列表中,并将删除的条目放入另一个列表中。这是当前代码:

        Map<Chunk, List<Player>> chunkListMap = new HashMap<>();

for (Chunk c : affectedChunks) {
List<Player> currentPlayers = playersInChunk(c);
if (!chunkListMap.containsKey(c)) {
chunkListMap.put(c, currentPlayers);
continue;
}
List<Player> previousPlayers = chunkListMap.get(c);

List<Player> enteringPlayers = new ArrayList<>(currentPlayers);
enteringPlayers.removeAll(previousPlayers);
for (Player player : enteringPlayers) applyEffects(player);

List<Player> leavingPlayers = new ArrayList<>(previousPlayers);
leavingPlayers.removeAll(currentPlayers);
for (Player player : leavingPlayers) unapplyEffects(player);
}

private List<Player> playersInChunk(Chunk c) {
List<Player> retVal = new ArrayList<>();
for (Entity e : c.getEntities()) if (e instanceof Player) retVal.add((Player) e);
return retVal;
}

两个结果列表(enteringPlayers和leavePlayers)始终为空。我做错了什么?

最佳答案

虽然不知道业务逻辑或看到完整的代码,但很难说出原因。但让我想想可能的原因是什么:

只有当 chunkListMap 中已经存在 Player 时,您才会执行 for 循环后面的代码。 block c 是您用来检索 previousPlayers 的内容。

        List<Player> previousPlayers = chunkListMap.get(c);

现在您还可以使用

提取 currentPlayers
        List<Player> currentPlayers = playersInChunk(c);

如果特定 Chunk 对象中的所有 currentPlayers 都是 Player 类型,这将意味着 currentPlayers 和 previousPlayers 相同。

如果你这样做:

        enteringPlayers.removeAll(previousPlayers);

它会从中删除所有条目。因此,您将看到 null。

下面这个肮脏而粗糙的例子将向您展示:

package collectionuse;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

class Entity{
String name;

public void setName(String name){
this.name = name;
}
}

class Chunk{
Entity[] entity;
String name;

Chunk(){

}

Chunk(String name){
this.name = name;
entity = new Entity[2];
Entity e1 = new Player();
Entity e2 = new Player();
e1.setName(name);
e2.setName("Dummy");
entity[0] = e1;
entity[1] = e2;
}

public Entity[] getEntities() {
return entity;
}
}

class Player extends Entity{

}

public class MapsT {

public void checkMap(){
Map<Chunk, List<Player>> chunkListMap = new HashMap<>();
List<Chunk> affectedChunks = new ArrayList<Chunk>();
Chunk ch = new Chunk("Z");
affectedChunks.add(0, ch);
affectedChunks.add(1, ch);

affectedChunks.add(2, new Chunk("A"));
affectedChunks.add(3, new Chunk("B"));
affectedChunks.add(4, new Chunk("C"));
affectedChunks.add(5, new Chunk("D"));

for (Chunk c : affectedChunks) {
List<Player> currentPlayers = playersInChunk(c);
if (!chunkListMap.containsKey(c)) {
chunkListMap.put(c, currentPlayers);
continue;
}

List<Player> previousPlayers = chunkListMap.get(c);
List<Player> enteringPlayers = new ArrayList<>(currentPlayers);
enteringPlayers.removeAll(previousPlayers);
//for (Player player : enteringPlayers) applyEffects(player);

List<Player> leavingPlayers = new ArrayList<>(previousPlayers);
leavingPlayers.removeAll(currentPlayers);
//for (Player player : leavingPlayers) unapplyEffects(player);
}

}

private List<Player> playersInChunk(Chunk c) {
List<Player> retVal = new ArrayList<>();
for (Entity e : c.getEntities()) {
if (e instanceof Player) retVal.add((Player) e);
}
return retVal;
}

public static void main(String[] args) {
MapsT mapt = new MapsT();
mapt.checkMap();
}

}

关于java - 比较两个列表并对添加和删除的条目进行排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36232306/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com