Alternatives for TimeUnit.SECONDS.sleep(1); SpigotMC/ SpigotMC event not running(TimeUnit.SECONDS的替代方案(1);SpigotMC/SpigotMC事件未运行)
问题描述
遇到此问题时,我正试图创建一个Minworld插件,但我认为这更像是一个Java讨论
所以我尝试创建一个每秒钟繁殖一只鸡的派生程序(对于测试,当我完成时,它将变成每一分钟),但当我测试时,事件似乎没有运行(因为TimeUnit.SECONDS.sleep()
将阻塞MC线程)。那么,我可以有另一个选择吗?
我现在使用的延迟是TimeUnit.SECONDS.sleep(*insert some number here*);
,如下所示:
注意:我已经尝试了使用答案中所示的setTaskTimer
和scheduleSyncRepeatingTask
,但它们似乎不起作用。这是事件问题还是spawnEntity
问题?
package com.TheRealBee.Bows.Event10;
import org.bukkit.ChatColor;
import org.bukkit.Material;
import org.bukkit.entity.EntityType;
import org.bukkit.event.EventHandler;
import org.bukkit.event.Listener;
import org.bukkit.event.block.BlockPlaceEvent;
import java.util.concurrent.TimeUnit;
public class EventManager10 implements Listener {
@EventHandler
public void onNukePlace(BlockPlaceEvent e){
// Return if it's not TNT, doesn't have ItemMeta or doesn't have a custom dispaly name
if(!e.getBlock().getType().equals(Material.GOLD_BLOCK) || !e.getItemInHand().hasItemMeta() || !e.getItemInHand().getItemMeta().hasDisplayName())
return;
// Return if the item display name is not correct
if(!e.getItemInHand().getItemMeta().getDisplayName().equals(ChatColor.WHITE+"Spawner"))
return;
// Create the explosion
try {
for (int i = 0; i < 300000000; i++) {
e.getBlock().getLocation().getWorld().spawnEntity(e.getBlock().getLocation(), EntityType.CHICKEN);
TimeUnit.SECONDS.sleep(1);
}
}
catch(InterruptedException ex)
{
Thread.currentThread().interrupt();
}
}
}
推荐答案应使用Bukkit.getScheduler().scheduleSyncRepeatingTask(...)
代替For循环和TimeUnit.SECONDS.sleep
Bukkit.getScheduler().scheduleSyncRepeatingTask(plugin, new Runnable() {
@Override
public void run() {
e.getBlock().getLocation().getWorld().spawnEntity(e.getBlock().getLocation(), EntityType.CHICKEN);
}
}, 0L, 20L)
Bukkit.getScheduler().scheduleSyncRepeatingTask(plugin, new Runnable() {
@Override
public void run() {
e.getBlock().getLocation().getWorld().spawnEntity(e.getBlock().getLocation(), EntityType.CHICKEN);
}
}, 0L, 20L)
plugin
应为您的插件的实例
0L
是运行第一个任务之前的延迟(以刻度为单位)
20L
是运行下一个任务之前的延迟(以刻度为单位)
scheduleSyncRepeatingTask in the Spigot JavaDoc
因为这是一个产卵程序,所以我认为当块被打破时,您会想要停止产卵。您可以使用任务ID取消任务。TaskID是scheduleSyncRepeatingTask
返回的整数。您应该保存此taskID,因为您可以在稍后(块中断时)取消该任务。要取消任务,可以使用cancelTask
:
Bukkit.getServer().getScheduler().cancelTask(taskID);
cancelTask in the Spigot JavaDoc
例如,使用HashMap保存此taskID。当块放置时,您应该将坐标保存为key,将taskID保存为HashMap中的值。当块被破坏时(使用块断开事件),您应该在该HashMap中查找被破坏的块的坐标。如果HashMap中存在坐标,则应取消任务并从HashMap中删除该条目。这篇关于TimeUnit.SECONDS的替代方案(1);SpigotMC/SpigotMC事件未运行的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:TimeUnit.SECONDS的替代方案(1);SpigotMC/SpigotMC事件未运行
基础教程推荐
- 如何对 HashSet 进行排序? 2022-01-01
- 首次使用 Hadoop,MapReduce Job 不运行 Reduce Phase 2022-01-01
- 由于对所需库 rt.jar 的限制,对类的访问限制? 2022-01-01
- 在螺旋中写一个字符串 2022-01-01
- 如何使用 Stream 在集合中拆分奇数和偶数以及两者的总和 2022-01-01
- Java 中保存最后 N 个元素的大小受限队列 2022-01-01
- 如何在不安装整个 WTP 包的情况下将 Tomcat 8 添加到 Eclipse Kepler 2022-01-01
- 如何强制对超级方法进行多态调用? 2022-01-01
- Spring Boot Freemarker从2.2.0升级失败 2022-01-01
- 如何使用 Eclipse 检查调试符号状态? 2022-01-01