getplayer()抛出一个数字格式异常

qcuzuvrc  于 2021-06-30  发布在  Java
关注(0)|答案(1)|浏览(377)

我对minecraft插件开发相当陌生,我正在尝试制作自己的精简版的软件包插件。我试着做一个命令,让我可以设置我的飞行速度以及其他人的飞行速度。设定速度效果很好,但是,瞄准其他玩家似乎是我无法管理的事情。当我执行命令时,它会出现在日志中:

[23:55:50 INFO]: swalloich issued server command: /flyspeed swalloich 2
[23:55:50 INFO]: swalloichtargeted swalloich with the flySpeed command.
[23:55:50 ERROR]: null
org.bukkit.command.CommandException: Unhandled exception executing command 'flyspeed' in plugin EssentialsLite v0.2
    at org.bukkit.command.PluginCommand.execute(PluginCommand.java:47) ~[craftbukkit-1.16.2.jar:git-Bukkit-43c7ff9]
    at org.bukkit.command.SimpleCommandMap.dispatch(SimpleCommandMap.java:148) ~[craftbukkit-1.16.2.jar:git-Bukkit-43c7ff9]
    at org.bukkit.craftbukkit.v1_16_R2.CraftServer.dispatchCommand(CraftServer.java:735) ~[craftbukkit-1.16.2.jar:git-Bukkit-43c7ff9]
    at net.minecraft.server.v1_16_R2.PlayerConnection.handleCommand(PlayerConnection.java:1647) ~[craftbukkit-1.16.2.jar:git-Bukkit-43c7ff9]
    at net.minecraft.server.v1_16_R2.PlayerConnection.a(PlayerConnection.java:1504) ~[craftbukkit-1.16.2.jar:git-Bukkit-43c7ff9]
    at net.minecraft.server.v1_16_R2.PacketPlayInChat.a(SourceFile:36) ~[craftbukkit-1.16.2.jar:git-Bukkit-43c7ff9]
    at net.minecraft.server.v1_16_R2.PacketPlayInChat.a(SourceFile:9) ~[craftbukkit-1.16.2.jar:git-Bukkit-43c7ff9]
    at net.minecraft.server.v1_16_R2.PlayerConnectionUtils.lambda$0(PlayerConnectionUtils.java:19) ~[craftbukkit-1.16.2.jar:git-Bukkit-43c7ff9]
    at net.minecraft.server.v1_16_R2.TickTask.run(SourceFile:18) ~[craftbukkit-1.16.2.jar:git-Bukkit-43c7ff9]
    at net.minecraft.server.v1_16_R2.IAsyncTaskHandler.executeTask(SourceFile:144) ~[craftbukkit-1.16.2.jar:git-Bukkit-43c7ff9]
    at net.minecraft.server.v1_16_R2.IAsyncTaskHandlerReentrant.executeTask(SourceFile:23) ~[craftbukkit-1.16.2.jar:git-Bukkit-43c7ff9]
    at net.minecraft.server.v1_16_R2.IAsyncTaskHandler.executeNext(SourceFile:118) ~[craftbukkit-1.16.2.jar:git-Bukkit-43c7ff9]
    at net.minecraft.server.v1_16_R2.MinecraftServer.ba(MinecraftServer.java:899) ~[craftbukkit-1.16.2.jar:git-Bukkit-43c7ff9]
    at net.minecraft.server.v1_16_R2.MinecraftServer.executeNext(MinecraftServer.java:892) ~[craftbukkit-1.16.2.jar:git-Bukkit-43c7ff9]
    at net.minecraft.server.v1_16_R2.IAsyncTaskHandler.awaitTasks(SourceFile:127) ~[craftbukkit-1.16.2.jar:git-Bukkit-43c7ff9]
    at net.minecraft.server.v1_16_R2.MinecraftServer.sleepForTick(MinecraftServer.java:876) ~[craftbukkit-1.16.2.jar:git-Bukkit-43c7ff9]
    at net.minecraft.server.v1_16_R2.MinecraftServer.w(MinecraftServer.java:815) ~[craftbukkit-1.16.2.jar:git-Bukkit-43c7ff9]
    at net.minecraft.server.v1_16_R2.MinecraftServer.lambda$0(MinecraftServer.java:155) ~[craftbukkit-1.16.2.jar:git-Bukkit-43c7ff9]
    at java.lang.Thread.run(Thread.java:832) [?:?]
Caused by: java.lang.NumberFormatException: For input string: "swalloich"
    at java.lang.NumberFormatException.forInputString(NumberFormatException.java:68) ~[?:?]
    at java.lang.Integer.parseInt(Integer.java:652) ~[?:?]
    at java.lang.Integer.parseInt(Integer.java:770) ~[?:?]
    at me.swall.essentialsLite.commands.FlySpeed.onCommand(FlySpeed.java:62) ~[?:?]
    at org.bukkit.command.PluginCommand.execute(PluginCommand.java:45) ~[craftbukkit-1.16.2.jar:git-Bukkit-43c7ff9]
    ... 18 more

我几乎可以肯定的是,我的代码中有这样一部分:

float flySpeed = (float)(Integer.parseInt(args[1]) / 10.0);
    Bukkit.getLogger().info(player.getDisplayName() + " targeted " + args[0] + " with the flySpeed command.");
    if (Integer.parseInt(args[0]) > 10 || Integer.parseInt(args[0]) < 0)
    {
        sender.sendMessage("The speed argument must be a whole number between 0 and 10.");
    }
    else
    {
        //set the target player's fly speed to the value provided as the second argument
        Player targetPlayer = Bukkit.getPlayerExact(args[0]);
        Bukkit.getLogger().info("targetPlayer was initialized.");
        if (targetPlayer != null && player.isOnline())
        {
            targetPlayer.setFlySpeed(flySpeed);
            Bukkit.getLogger().info("The fly speed for user " + player.getDisplayName() 
                                    + " has been set to" + args[0]);
        }
        else
        {
            sender.sendMessage("That player was not found.");
        }
    }

我做错什么了?

of1yzvn4

of1yzvn41#

在代码的第1行,您将字符串(args[1])除以float(10.0)。

float flySpeed = (float)(Integer.parseInt(args[1] / 10.0));

应改为:

float flySpeed = (float)(Integer.parseInt(args[1]) / 10.0);

+如果要在代码中多次使用已解析的整数,我建议为此创建整数变量。
如果是这样,代码将如下所示:

int flySpeedArg = Integer.parseInt(args[1]);
    float flySpeed = (float)(Integer.parseInt(args[1]) / 10.0);

    Bukkit.getLogger().info(player.getDisplayName() + " targeted " + args[0] + " with the flySpeed command.");
    if (flySpeedArg > 10 || flySpeedArg < 0)
    {
        sender.sendMessage("The speed argument must be a whole number between 0 and 10.");
    }
    else
    {
        //set the target player's fly speed to the value provided as the second argument
        Player targetPlayer = Bukkit.getPlayerExact(args[0]);
        Bukkit.getLogger().info("targetPlayer was initialized.");
        if (targetPlayer != null && player.isOnline())
        {
            targetPlayer.setFlySpeed(flySpeed);
            Bukkit.getLogger().info("The fly speed for user " + player.getDisplayName() 
                                    + " has been set to" + args[0]);
        }
        else
        {
            sender.sendMessage("That player was not found.");
        }
    }

相关问题