【发布时间】:2018-07-30 08:39:49
【问题描述】:
我的代码应该彻底解释我的问题。我需要读取整个文件并获取每一行的数据,然后应用该数据。我在读取整个文件并获取每行数据时遇到问题。它还将整个程序发送到一个无限循环中。我添加了一些发送到控制台的调试消息。这就是“Logger.log(”)”的含义。他们正在向控制台发送调试消息。这是我的代码:
编辑:我通过将“while (fileList.length != 0)”更改为“if (fileList.length != 0)”解决了循环问题,但现在出现了在调试消息之后无法继续操作的问题“记录器.log("14")"。
public void setItems(Inventory inv)
{
try
{
if (!kit.getDataFolder().exists())
{
kit.getDataFolder().mkdirs();
}
Logger.log("1");
File folder = files.getFolder("GUI Menu");
Logger.log("2");
if (!folder.exists())
{
files.createFolder("GUI Menu");
}
File[] fileList = folder.listFiles();
Logger.log("3");
if (fileList.length != 0)
{
Logger.log("4");
for (File forFile : fileList)
{
Logger.log("5");
File file = files.getGuiItem(forFile);
Logger.log("6");
if (!file.exists())
{
Logger.log("Cannot open Inventory for the file");
return;
}
Logger.log("7");
BufferedReader br = new BufferedReader(new FileReader(file));
Logger.log("8");
String line;
Logger.log("9");
while ((line = br.readLine()) != null)
{
Logger.log("10");
ItemStack item;
if (line.contains("Item ID: "))
{
Logger.log("11");
String[] tSplit = line.split(": ");
String split = tSplit[1];
Logger.log("12");
if (StringCheck.isInteger(split))
{
Logger.log("13");
Material mat = Material.matchMaterial(split);
ItemStack item1 = new ItemStack(mat, 1);
item = item1;
Logger.log("14");
if (line.contains("Kit Name: "))
{
String[] jSplit = line.split(": ");
String j2split = jSplit[1];
Logger.log("15");
if (item != null && !item.equals(Material.AIR))
{
ItemMeta meta = item.getItemMeta();
meta.setDisplayName(Color.add("&6" + j2split + "&e Kit"));
item.setItemMeta(meta);
Logger.log("16");
if (line.contains("Price: "))
{
String[] pSplit = line.split(": ");
String p2split = pSplit[1];
Logger.log("17");
if (item != null && !item.equals(Material.AIR))
{
this.setLore(item, "&ePrice: &6" + p2split);
if (line.contains("Slot Number: "))
{
Logger.log("18");
String[] fSplit = line.split(": ");
String f2split = fSplit[1];
if (StringCheck.isInteger(f2split))
{
Logger.log("19");
if (item != null && !item.equals(Material.AIR))
{
Logger.log("20");
if (inv.getItem(Integer.parseInt(split)) == null || inv.getItem(Integer.parseInt(split)).equals(Material.AIR))
{
inv.setItem(Integer.parseInt(split), item);
}
}
}
}
}
}
}
}
}
}
}
br.close();
}
}
} catch (Exception e)
{
e.printStackTrace();
}
}
【问题讨论】:
-
while (fileList.length != 0)应该是if声明 -
嗯,这能解决我的问题吗?
-
它将 1- 使其更具可读性和 2- 降低陷入无限循环的风险
-
好的,改了。还有什么你可以发现的错误吗?
-
我仍然不知道您为什么同时使用
BufferedReader和Scanner。我还鼓励您使用try-with-resources statement 来更好地管理您的资源
标签: java file minecraft reader