我正在做一个迷你游戏。如果有2位玩家在线,则倒数开始。我正在用我的2个帐户进行测试。当1个帐户登录时,我会得到一把钻石剑。没关系。但是,当我使用第二个帐户登录时,倒数计时不会开始,并且出现错误。我不知道是什么问题。你能帮我么?非常感谢你。

这是错误:

[15:41:29 ERROR]: Could not pass event PlayerJoinEvent to Minigame v1.0.0
    org.bukkit.event.EventException
            at org.bukkit.plugin.java.JavaPluginLoader$1.execute(JavaPluginLoader.ja
    va:302) ~[craftbukkit.jar:git-Bukkit-53fac9f]
            at org.bukkit.plugin.RegisteredListener.callEvent(RegisteredListener.jav
    a:62) ~[craftbukkit.jar:git-Bukkit-53fac9f]
            at org.bukkit.plugin.SimplePluginManager.fireEvent(SimplePluginManager.j
    ava:501) [craftbukkit.jar:git-Bukkit-53fac9f]
            at org.bukkit.plugin.SimplePluginManager.callEvent(SimplePluginManager.j
    ava:486) [craftbukkit.jar:git-Bukkit-53fac9f]
            at net.minecraft.server.v1_8_R3.PlayerList.onPlayerJoin(PlayerList.java:
    282) [craftbukkit.jar:git-Bukkit-53fac9f]
            at net.minecraft.server.v1_8_R3.PlayerList.a(PlayerList.java:142) [craft
    bukkit.jar:git-Bukkit-53fac9f]
            at net.minecraft.server.v1_8_R3.LoginListener.b(LoginListener.java:115)
    [craftbukkit.jar:git-Bukkit-53fac9f]
            at net.minecraft.server.v1_8_R3.LoginListener.c(LoginListener.java:53) [
    craftbukkit.jar:git-Bukkit-53fac9f]
            at net.minecraft.server.v1_8_R3.NetworkManager.a(NetworkManager.java:222
    ) [craftbukkit.jar:git-Bukkit-53fac9f]
            at net.minecraft.server.v1_8_R3.ServerConnection.c(SourceFile:168) [craf
    tbukkit.jar:git-Bukkit-53fac9f]
            at net.minecraft.server.v1_8_R3.MinecraftServer.B(MinecraftServer.java:7
    44) [craftbukkit.jar:git-Bukkit-53fac9f]
            at net.minecraft.server.v1_8_R3.DedicatedServer.B(DedicatedServer.java:3
    35) [craftbukkit.jar:git-Bukkit-53fac9f]
            at net.minecraft.server.v1_8_R3.MinecraftServer.A(MinecraftServer.java:6
    28) [craftbukkit.jar:git-Bukkit-53fac9f]
            at net.minecraft.server.v1_8_R3.MinecraftServer.run(MinecraftServer.java
    :536) [craftbukkit.jar:git-Bukkit-53fac9f]
            at java.lang.Thread.run(Unknown Source) [?:1.8.0_60]
    Caused by: java.lang.NullPointerException
            at me.KevinGDev.Listeners.Player.PlayerJoin.onPlayerJoin(PlayerJoin.java
    :41) ~[?:?]
            at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[?:1.8.0
    _60]
            at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source) ~[?:1.8.0
    _60]
            at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source) ~[?:1
    .8.0_60]
            at java.lang.reflect.Method.invoke(Unknown Source) ~[?:1.8.0_60]
            at org.bukkit.plugin.java.JavaPluginLoader$1.execute(JavaPluginLoader.ja
    va:300) ~[craftbukkit.jar:git-Bukkit-53fac9f]
            ... 14 more


这是我的PlayerJoinEvent:

public class PlayerJoin extends MListener {

    public static Minigame plugin;

    public PlayerJoin(Minigame pl) {
        super(pl);
    }

    @EventHandler
    public void onPlayerJoin(PlayerJoinEvent event) {
        Player player = event.getPlayer();

        LocationUtilities.teleportToSpawn(player);
        InventoryUtilities.clearInventory(player);

        ItemStack is = new ItemStack(Material.DIAMOND_SWORD);
        ItemMeta im = is.getItemMeta();
        im.setDisplayName(ChatColor.GREEN + "Kits");
        is.setItemMeta(im);
        player.getInventory().addItem(is);

        if(Bukkit.getServer().getOnlinePlayers().size() >= 2) {
            ChatUtilties.broadcast("Enough players. Starting countdown!");
            plugin.startCountdown();
        }
 }


PlayerJoinEvent位于PlayerJoin类中。
startCountdown方法位于Minigame类(主类)中。

startCountdown方法:

public void startCountdown() {
    StartCountdown.timeUntilStart = 60;
    startCountdownId = getServer()
            .getScheduler()
            .scheduleSyncRepeatingTask(this, new StartCountdown(this), 20l, 20l);

最佳答案

在您的堆栈跟踪中,我可以看到您在事件方法“ onPlayerJoin”中得到了NullPointerException。

我看到以下内容:

public static Minigame plugin;

public PlayerJoin(Minigame pl) {
    super(pl);
}


您有两个不同的“迷你游戏”对象。您提供给MListener的一个和未初始化的一个。那应该是你的问题。
“ plugin.startCountdown();”因此,调用导致Exception。您可以对未初始化的对象(“ null”)调用startCountdown()方法。

有两种解决方法:


初始化插件变量
在“ pl”上调用“ startCountdown()”


因此,采用第一个解决方案:

public PlayerJoin(Minigame pl) {
    super(pl);
    plugin = pl;
}


我不建议这样做,因为它处理https://en.wikipedia.org/wiki/Static_variable变量比较麻烦。

第二种解决方案:

我认为对您来说,有可能(通过getter或直接调用)访问“ pl”对象。在您的EventListener中使用它:

 [pl/getPl()/getPlugin()].startCountdown();

09-28 06:48